IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C# Discussion :

Vérifier une requête sql


Sujet :

C#

  1. #1
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2013
    Messages
    86
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Août 2013
    Messages : 86
    Points : 56
    Points
    56
    Par défaut Vérifier une requête sql
    Bonjour à tous,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    string strdb = @"Data Source=X;Database = X;User Id=X;Password=X;";
                string qry = "SELECT room FROM roomchecked WHERE username = " + jc.User + ";";
                MySqlConnection conDataBase = new MySqlConnection(strdb);
                MySqlCommand commande = conDataBase.CreateCommand();
                MySqlDataReader myReaders;
     
                conDataBase.Open();
                commande.CommandText = qry;
     
                myReaders = commande.ExecuteReader();
    J'ai ce bout de code pour une requete SQL.
    Ma table roomchecked est actuellement vide, du coup, la dernière ligne me renvoie une erreur "Unknown column 'X' in 'where clause' ". Comment puis-je contourner le pb ?

    Merci

  2. #2
    Expert éminent sénior Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 154
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 154
    Points : 25 072
    Points
    25 072
    Par défaut
    ceci est un message d'erreur car ta syntaxe n'est pas bonne

    =>

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    string qry = "SELECT room FROM roomchecked WHERE username = '" + jc.User + "';";
    (un string doit être entre quote en sql)

    le mieux est d'utiliser les requetes paramétrées (ca évite les problèmes avec les ' contenus dans le string, le problème avec les formats de date, et les injections sql)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    string qry = "SELECT room FROM roomchecked WHERE username = @username";
    commande.parameters.add("@username",le type).value = jc.User;  // syntaxe exacte à vérifier
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  3. #3
    Membre confirmé Avatar de Jabbal'H
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2004
    Messages
    403
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2004
    Messages : 403
    Points : 580
    Points
    580
    " Je préfère comprendre les gens qui ne me comprennent pas "

  4. #4
    Membre chevronné
    Avatar de PixelJuice
    Homme Profil pro
    Ingénieur .NET & Game Designer
    Inscrit en
    Janvier 2014
    Messages
    640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Ingénieur .NET & Game Designer
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2014
    Messages : 640
    Points : 2 149
    Points
    2 149
    Par défaut
    Bonjour,

    Sache que même la table vide , une requête avec une clause WHERE ne trouvera rien mais ne générera aucune erreur.

    C'est une erreur de syntaxe , comme Pol63 l'a dit , en SQL on aime pas trop les string sans ' ' dans les WHERE clause.

  5. #5
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2013
    Messages
    86
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Août 2013
    Messages : 86
    Points : 56
    Points
    56
    Par défaut
    Ah ouais, en effet ... j'ai oublié les simples quotes..
    Merci beaucoup

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Vérifier la syntaxe d'une requêté SQL
    Par sihamnet dans le forum JDBC
    Réponses: 7
    Dernier message: 11/11/2014, 15h13
  2. Vérifier la syntaxe d'une requête SQL ?
    Par brolon dans le forum JDBC
    Réponses: 7
    Dernier message: 03/04/2009, 16h13
  3. Utilisation de MAX dans une requête SQL
    Par Evil onE dans le forum Langage SQL
    Réponses: 7
    Dernier message: 15/06/2004, 18h38
  4. Résultat d'une requète SQL
    Par camino dans le forum Bases de données
    Réponses: 2
    Dernier message: 21/02/2004, 15h22
  5. A propos d'une requête SQL sur plusieurs tables...
    Par ylebihan dans le forum Langage SQL
    Réponses: 2
    Dernier message: 14/09/2003, 16h26

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo