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 :

Erreur Syntaxe sqlite


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Inscrit en
    Juillet 2010
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Juillet 2010
    Messages : 2
    Par défaut Erreur Syntaxe sqlite
    bonjour j'ai un problème de syntaxe avec mon sqlite sur visual basic 2008 , je code avec le langage c#.J'arrive pas a trouver l'erreur sur ma requète, si quelqu'un peut m'aider:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     cmd.CommandText = "UPDATE client SET (nom = '" + nom + "', prenom='" + prenom + "',carte_identite='" + carte_identite + "',adresse='" + adresse + "',numero_tel='" + telephone + "',email='" + mail + "' WHERE carte_identite= +"+carte_identite+"); ";

  2. #2
    Membre émérite Avatar de ctxnop
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2007
    Messages
    858
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2007
    Messages : 858
    Par défaut
    Bah moi je vois deux problèmes d'un coup d'oeil
    Le premier :
    Tu dis coder en C# dans Visual Basic... Bah ca risque pas de marcher. Donc C# ou VB ? Quand c'est en VB le vrai opérateur de concaténation des chaines c'est le '&', pas le '+' et il n'y a pas de ';' final.
    Le second :
    Pas bien du tout de créer ta chaine comme ca, elle devient sensible à l'injection SQL.
    Sur l'objet cmd tu troruvera une collection 'Parameters'

    Code csharp : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    cmd.CommandText = "UPDATE client SET (nom = @NOM)";
    cmd.Parameters.Add(new SqlParameter("@NOM", nom));

    Cette façon de faire t'assure que quelque soit le type du paramètre il est passé correctement sans injection possible. Tu remarquera l'absence des ' autour du paramètre, ceux-ci seront rajouté tout seul car le paramètre est de type system.string.

    Sortie de ca, niveau SQL pure, tu t'es aussi planté dans tes parenthèses. Tu la commence avant l'instruction SET et tu la fini après le WHERE.
    Dans ton cas les parenthèses ne sont de toute façon pas utiles.

  3. #3
    Nouveau candidat au Club
    Inscrit en
    Juillet 2010
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Juillet 2010
    Messages : 2
    Par défaut
    je me suis tromper c'est sur visual studio 2008. Bon je vais essayer de faire ce que tu as dit aprés je vais te dire.

  4. #4
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Par défaut
    Citation Envoyé par kaizer88 Voir le message
    je me suis tromper c'est sur visual studio 2008. .
    Et bien en C# ?

  5. #5
    Membre émérite Avatar de ctxnop
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2007
    Messages
    858
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2007
    Messages : 858
    Par défaut
    En fait il y a deux erreurs de syntaxes dans ta requête. Sans prendre en compte mon histoire de SqlParameter, voilà ce que devrait être ta requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    cmd.CommandText = "UPDATE client SET nom = '" + nom + "', prenom = '" + prenom + "', carte_identite = '" + carte_identite + "', adresse = '" + adresse + "', numero_tel = '" + telephone + "', email = '" + mail + "' WHERE carte_identite = '" + carte_identite + "'";
    La première erreur étant les parenthèses qui n'avaient aucune utilité et surtout était mal placées puisque tu la fermait avait écris " UPDATE client SET (... WHERE ...)".
    La seconde erreur n'aurait pas eu lieu avec l'utilisation des SqlParameters, ce sont des '" + variable + "' a répétition qui rendent l'erreur dur à voir.
    Mais regardes bien ton WHERE, tu as écris " WHERE carte_identite= +"+ "

    Edit:
    En fait, en corrigeant un oublie de ma part me suis apercu qu'il y a une troisième erreur ^^'
    Dans la clause SET tu met la valeur de carte_identite entre ''
    Bon déjà ca sert a rien de faire un update de cette valeur puisque y'a un where qui ne sélectionne que les lignes pour lesquelles la valeur est déjà celle-ci. Mais surtout, dans ce WHERE, la valeur n'est pas mise entre ''.

  6. #6
    Membre éclairé Avatar de poussinphp
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    428
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 428
    Par défaut
    Pour éviter ce genre de problèmes, je te conseil d'utiliser le string.Format. c'est plus lisible

    ex:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    cmd.CommandText = string.Format(@"UPDATE client SET (nom ='{0}', prenom='{1}',carte_identite='{2}',adresse='{3}',numero_tel='{4}',email= '{5}' WHERE carte_identite='{2}');", nom, prenom, carte_identite, adresse, numero_tel, email);
    cela dit, je reste d'avis qu'il vaut mieux utiliser des requêtes paramétrées car c'ets plus simple, plus lisible et ça t'évite de l'injection sql dans ton code car là coté sécurité, c'est pas terrible.

  7. #7
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Par défaut
    Citation Envoyé par poussinphp Voir le message
    Pour éviter ce genre de problèmes, je te conseil d'utiliser le string.Format. c'est plus lisible
    Non, dans ce cas on utilise les paramètres, si on veut faire propre.

Discussions similaires

  1. Erreur syntaxe
    Par Anduriel dans le forum Général JavaScript
    Réponses: 8
    Dernier message: 27/12/2005, 19h45
  2. [erreur syntaxe]
    Par viny dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 15/11/2005, 15h49
  3. Erreur syntaxe
    Par diaboloche dans le forum Langage
    Réponses: 12
    Dernier message: 19/10/2005, 16h47
  4. erreur syntaxe dans requete
    Par dom - ien moutiers dans le forum Requêtes
    Réponses: 5
    Dernier message: 19/04/2004, 11h54
  5. [EXISTS] Version MySql ou erreur syntaxe ?
    Par Kimael dans le forum Requêtes
    Réponses: 5
    Dernier message: 01/04/2004, 17h30

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