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

VB 6 et antérieur Discussion :

Problème avec erreur d'exécution


Sujet :

VB 6 et antérieur

  1. #1
    Membre régulier Avatar de bruce207
    Inscrit en
    Novembre 2007
    Messages
    319
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 319
    Points : 124
    Points
    124
    Par défaut Problème avec erreur d'exécution
    Bonjour,
    mon problème est le suivant : j'ai un bouton command, des textbox et une bdd, lorsque je saisis cette phrase dans un textbox : Connecté à l'eau et l'électricité et que je l'insere dans la base de données par la requete suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MyCon.Execute " UPDATE piece set mat_loc = '" & TxtLoc(0).Text & "', date_limite_vers = " & TxtLoc(4).Text & ", date_location = '" & TxtLoc(2).Text & "', duree_location = " & TxtLoc(3).Text & ", montant_loyer = " & TxtLoc(7).Text & ", type_loc = '" & Combo1.Text & "', caracteristique = '" & TxtLoc(5).Text & "', description = '" & TxtLoc(6).Text & "' where mat_loc = '" & TxtLoc(0).Text & "'"
    le débogeur s'arrete sur la requete et m'affiche l'erreur suivante :
    Erreur d'exécution '-2147217900(80040e14)':
    Erreur de syntaxe (opérateur absent) dans l'expression " Connecté à l'eau et l'électricité".
    le textbox est ici TxtLoc(5).Text et le champ caracteristique est de type Text dans une bdd ACCESS 2003
    pourquoi cette erreur et comment y remedier ?

  2. #2
    Membre expert Avatar de OhMonBato
    Homme Profil pro
    Inscrit en
    Mars 2007
    Messages
    2 660
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2007
    Messages : 2 660
    Points : 3 685
    Points
    3 685
    Par défaut
    Si tu enlèves les apostrophes dans ton expression as tu toujours l'erreur ?
    Si oui, essaye de doubler les apostrophes dans ta chaine avant de la mettre dans ta requête.
    Connecté à l''eau et l''électricité
    Pour VB6 : N'oubliez pas d'aller voir la FAQ et les Tutoriels
    Vous trouvez une reponse particulierement utile ? Votez pour !

  3. #3
    Membre expert
    Avatar de Delbeke
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    2 675
    Détails du profil
    Informations personnelles :
    Âge : 70
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 2 675
    Points : 3 696
    Points
    3 696
    Par défaut
    Comme le dit OhMonbato, il faut remplacer le simple quote dans le contenu des champs par un double.
    Voici un exemple de ce que çà peut donner
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    SQl = " UPDATE piece " & _
              "set       mat_loc = '" & _
                                 Replace(TxtLoc(0).Text, "'","''") & _
                         "', date_limite_vers = " & _
                                 TxtLoc(4).Text & _
                         ", date_location = '" & _
                                 TxtLoc(2).Text & _
                         "', duree_location = " & _
                                TxtLoc(3).Text & _
                         ", montant_loyer = " & _
                                TxtLoc(7).Text & _
                         ", type_loc = '" & _
                                Replace(Combo1.Text, "'","''") & _
                         "', caracteristique = '" & _
                                Replace(TxtLoc(5).Text, "'","''") & _
                         "', description = '" & _
                                Replace(TxtLoc(6).Text, "'","''") & _
                         "' where mat_loc = '" & _
                                Replace(TxtLoc(0).Text, "'","''") & _
                         "'"
    Debug.Print SQL
    MyCon.Execute SQL
    par ailleurs, je te conseille, comme je le montre dans le code, d'utiliser le caractère de contination de ligne quand les lignes sont longue, çà aide à mieux cerner le code
    Je te conseille également de mettre ta requete dans une chaine de caractères, ce qui te permettra d'avoir une visualisation de la chaine exécutée.
    De plus j'ai vu un champ nommé date_location. si ce champ est au format date, la syntaxe n'est pas bonne. il faudrait remplacer par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
       ", date_location = " & _
                                 cvdate(TxtLoc(2).Text )& _

    Dernière chose, tu fais un set de mat_loc et une selection sur mat_loc
    ce qui en simplifiant la requete à ce champs ferait
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SQl = " UPDATE piece " & _
              "set       mat_loc = '" & _
                                 Replace(TxtLoc(0).Text, "'","''") & _
                         "' where mat_loc = '" & _
                                Replace(TxtLoc(0).Text, "'","''") & _
                         "'"
    Ce qui est assez inutile je pense
    En général, on ne demande de conseils que pour ne pas les suivre ou, si on les a suivis, reprocher à quelqu'un de les avoir donnés
    (ALEXANDRE DUMAS)

    N'hésitez pas à visiter ma page de contributions

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

Discussions similaires

  1. problème avec le .jar exécutable et les fichier .jrxml
    Par asma2009 dans le forum Entrée/Sortie
    Réponses: 0
    Dernier message: 23/07/2009, 11h05
  2. J'ai un problème avec Wascana, il exécute "scanf" avant "printf"
    Par Tiétio dans le forum Eclipse C & C++
    Réponses: 9
    Dernier message: 29/01/2009, 09h36
  3. Problème avec un .jar exécutable
    Par neophytus dans le forum Débuter avec Java
    Réponses: 1
    Dernier message: 17/12/2008, 08h57
  4. Réponses: 2
    Dernier message: 26/09/2008, 12h23
  5. Problème avec mon premier exécutable en java
    Par Icefire dans le forum Débuter avec Java
    Réponses: 9
    Dernier message: 25/04/2008, 09h42

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