C
C#3mo ago
Kurisu 🐧

Issue with SQlite command

List<(string IDClash, int IDDiscord)> joueursIDs = new List<(string, int)>();

using (SqliteConnection connection = new SqliteConnection(connectionString))
{
connection.Open();

// Requête pour récupérer uniquement les IDClash et IDDiscord
string query = "SELECT IDClash, IDDiscord FROM Joueur";

using (SqliteCommand command = new SqliteCommand(query, connection))
using (SqliteDataReader reader = command.ExecuteReader())
{
while (reader.Read())
{
// Récupérer IDClash et IDDiscord et les ajouter à la liste
string idClash = reader.GetString(0);
int idDiscord = reader.GetInt32(1);
joueursIDs.Add((idClash, idDiscord));
}
}
}
List<(string IDClash, int IDDiscord)> joueursIDs = new List<(string, int)>();

using (SqliteConnection connection = new SqliteConnection(connectionString))
{
connection.Open();

// Requête pour récupérer uniquement les IDClash et IDDiscord
string query = "SELECT IDClash, IDDiscord FROM Joueur";

using (SqliteCommand command = new SqliteCommand(query, connection))
using (SqliteDataReader reader = command.ExecuteReader())
{
while (reader.Read())
{
// Récupérer IDClash et IDDiscord et les ajouter à la liste
string idClash = reader.GetString(0);
int idDiscord = reader.GetInt32(1);
joueursIDs.Add((idClash, idDiscord));
}
}
}
No description
20 Replies
Kurisu 🐧
Kurisu 🐧OP3mo ago
When I try to execute that Query I've this error. The table "Joueur" doesn't exist but when I do a .schema in my DB file, the table exist What's the issue? The connection string point to the good file
✿ Scarlet ✿
✿ Scarlet ✿3mo ago
What is the casing of Joeur?
Kurisu 🐧
Kurisu 🐧OP3mo ago
Player in french
✿ Scarlet ✿
✿ Scarlet ✿3mo ago
Also the schema Casing
Kurisu 🐧
Kurisu 🐧OP3mo ago
.schema is an internal command in SQlite To see the currents tables
✿ Scarlet ✿
✿ Scarlet ✿3mo ago
Casing like, is it "Joeur", "JOEUR", "joeur"
Kurisu 🐧
Kurisu 🐧OP3mo ago
Nah I verified that
✿ Scarlet ✿
✿ Scarlet ✿3mo ago
What is the schema where the table is located? Have you tried [schema].Joeur?
SG97
SG973mo ago
what's the actual connection string
Kurisu 🐧
Kurisu 🐧OP3mo ago
@"Data Source=C:\Users\Utilisateur\source\repos\DiscordBotIEN\IENDB.sqlite, Version=3"
Jimmacle
Jimmacle3mo ago
if it's a relative path there's a very good chance you're opening a different file than you think you are
Kurisu 🐧
Kurisu 🐧OP3mo ago
That's the schema
No description
SG97
SG973mo ago
in-memory db? hmm, nvm
Kurisu 🐧
Kurisu 🐧OP3mo ago
That's a sqlite file located in my project When I execute my query in Sqlite itself, it works
Buddy
Buddy3mo ago
Note that your database must exist in bin/debug or bin/release depending on your config AKA the current working directory
Jimmacle
Jimmacle3mo ago
not with an absolute path
Buddy
Buddy3mo ago
Oh it was absolute, my bad
Jimmacle
Jimmacle3mo ago
i have seen things like one tool creating the database with a WAL file and the C# code not reading it leading to wrong data is there just the .sqlite file or are there other db-related files there too?
Buddy
Buddy3mo ago
I mean you can try with relative path and just copy the db to output option in properties of the db file
Kurisu 🐧
Kurisu 🐧OP3mo ago
just that DB Same error with a relative path
CREATE TABLE Joueur (
IDDiscord INTEGER,
IDClash TEXT PRIMARY KEY, -- Clé primaire
Clan TEXT,
Role TEXT,
MembreDepuis DATE,
AQuitte DATE
);
CREATE TABLE Sanction (
IDSanction INTEGER PRIMARY KEY, -- Clé primaire
Type TEXT NOT NULL,
DateSanction DATE NOT NULL,
IDClash TEXT, -- Clé étrangère qui référence la table Joueur
FOREIGN KEY (IDClash) REFERENCES Joueur(IDClash) ON DELETE CASCADE
);
CREATE TABLE Joueur (
IDDiscord INTEGER,
IDClash TEXT PRIMARY KEY, -- Clé primaire
Clan TEXT,
Role TEXT,
MembreDepuis DATE,
AQuitte DATE
);
CREATE TABLE Sanction (
IDSanction INTEGER PRIMARY KEY, -- Clé primaire
Type TEXT NOT NULL,
DateSanction DATE NOT NULL,
IDClash TEXT, -- Clé étrangère qui référence la table Joueur
FOREIGN KEY (IDClash) REFERENCES Joueur(IDClash) ON DELETE CASCADE
);
List<(string IDClash, int IDDiscord)> joueursIDs = new List<(string, int)>();

using (SqliteConnection connection = new SqliteConnection(connectionString))
{
connection.Open();

// Requête pour récupérer uniquement les IDClash et IDDiscord
string query = "SELECT IDClash, IDDiscord FROM Joueur";

using (SqliteCommand command = new SqliteCommand(query, connection))
using (SqliteDataReader reader = command.ExecuteReader()) //the exception appear here

{
while (reader.Read())
{
// Récupérer IDClash et IDDiscord et les ajouter à la liste
string idClash = reader.GetString(0);
int idDiscord = reader.GetInt32(1);
joueursIDs.Add((idClash, idDiscord));
}
}
}

// Affichage des IDClash et IDDiscord
foreach (var joueurID in joueursIDs)
{
Console.WriteLine($"IDClash: {joueurID.IDClash}, IDDiscord: {joueurID.IDDiscord}");
}
List<(string IDClash, int IDDiscord)> joueursIDs = new List<(string, int)>();

using (SqliteConnection connection = new SqliteConnection(connectionString))
{
connection.Open();

// Requête pour récupérer uniquement les IDClash et IDDiscord
string query = "SELECT IDClash, IDDiscord FROM Joueur";

using (SqliteCommand command = new SqliteCommand(query, connection))
using (SqliteDataReader reader = command.ExecuteReader()) //the exception appear here

{
while (reader.Read())
{
// Récupérer IDClash et IDDiscord et les ajouter à la liste
string idClash = reader.GetString(0);
int idDiscord = reader.GetInt32(1);
joueursIDs.Add((idClash, idDiscord));
}
}
}

// Affichage des IDClash et IDDiscord
foreach (var joueurID in joueursIDs)
{
Console.WriteLine($"IDClash: {joueurID.IDClash}, IDDiscord: {joueurID.IDDiscord}");
}
private static readonly string connectionString = @"Data Source=C:\Users\Utilisateur\source\repos\DiscordBotIEN\IENDB.sqlite";
private static readonly string connectionString = @"Data Source=C:\Users\Utilisateur\source\repos\DiscordBotIEN\IENDB.sqlite";
The exception throw when we reach the using with the reader

Did you find this page helpful?