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.NET Discussion :

Problème avec instruction update oledbconnection [Débutant]


Sujet :

VB.NET

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Février 2013
    Messages
    51
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2013
    Messages : 51
    Par défaut Problème avec instruction update oledbconnection
    Bonjour à tous,

    J'essaye de mettre à jour le champ password de ma table Users en fonction du userid...

    Voici mon code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
          Dim chemin As String = Application.StartupPath & "\Config\myDB.mdb"
            Dim conn As New OleDbConnection("Provider=Microsoft.jet.oledb.4.0;data source=" & chemin)
            Dim qry As New OleDbCommand("update Users set password='" & TextBox3.Text & "' where userid=" & LoginForm1.user, conn)
     
            Try
                conn.Open()
                qry.ExecuteNonQuery()
                conn.Close()
                MsgBox("Record Updated")
            Catch ex As Exception
                MsgBox(ex.ToString)
            End Try
    Message d'erreur : " Erreur de syntaxe dans l’instruction UPDATE" ??

    Un pro du SQL pourrait-il m'éclairer ??

    Merci !

  2. #2
    Membre Expert


    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2006
    Messages
    970
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Belgique

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

    Informations forums :
    Inscription : Avril 2006
    Messages : 970
    Par défaut
    Je pencherais pour deux problèmes possibles :

    - Users qui pourraient être un mot clé du SGBD (je pense pas dans ce cas vu que cela ressemble à une connexion access).
    - Le password contiendrait le caractère '

    Dans tout les cas préférer l'utilisation des requêtes paramétrées qui permettent d'éviter pas mal d'erreurs de syntaxe (entre autre)
    Articles sur les technologies .NET

    Une réponse vous a aidé ? utilisez le bouton

    Votre problème est résolu ? utilisez le bouton

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Février 2013
    Messages
    51
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2013
    Messages : 51
    Par défaut
    Bonjour infosam76, merci pour ta réponse.

    - Oui c'est bien une connexion access
    - Je n'ai pas de caractère ' dans mon mot de passe, juste des chiffres...

    Je regarde en parallèle pour les requêtes paramétrées, que je ne connais pas du tout.

    Merci

  4. #4
    Membre Expert Avatar de _Ez3kiel
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2013
    Messages
    836
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Janvier 2013
    Messages : 836
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    userid=" & LoginForm1.user
    User est une property de LoginForm1 de type integer ? Si non n'oublie pas les apostrophes. userid='" & LoginForm1.user & "'" (Mais tu n'aurais pas eu ce souci avec une requête paramétrée.

    Au niveau de ta BDD c'est une clé primaire unique ?

    N'hésite pas à faire une msgbox de qry.CommandText pour voir la requête "formée" avec les valeurs avant l'ajout.

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Février 2013
    Messages
    51
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2013
    Messages : 51
    Par défaut
    Bonjour à tous, j'ai le même problème avec une requête paramétrée, voici mon code, la requête, et le message d'erreur :

    Code :

    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
     
     Using cn As New OleDbConnection("PROVIDER=Microsoft.JET.OLEDB.4.0;Data Source =C:\myDB.mdb"), _
             cmd As New OleDbCommand("UPDATE [Users] SET password= ? WHERE userid= ? ;", cn)
     
                ''# Note: I normally don't use AddWithValue(), but I don't know your data types
                cmd.Parameters.AddWithValue("?", TextBox3.Text)
                cmd.Parameters.AddWithValue("?", TextBox1.Text)
     
                Try
                    cn.Open()
                    cmd.ExecuteNonQuery()
     
                    MsgBox("done")
                Catch ex As Exception
                    MsgBox(cmd.CommandText)
                    MsgBox(ex.ToString)
                End Try
            End Using
    Requête :



    Erreur :



    Je remarque qu'il ne modifie pas les paramètres "?" ??

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Février 2013
    Messages
    51
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2013
    Messages : 51
    Par défaut
    Citation Envoyé par _Ez3kiel Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    userid=" & LoginForm1.user
    User est une property de LoginForm1 de type integer ? Si non n'oublie pas les apostrophes. userid='" & LoginForm1.user & "'" (Mais tu n'aurais pas eu ce souci avec une requête paramétrée.

    Au niveau de ta BDD c'est une clé primaire unique ?

    N'hésite pas à faire une msgbox de qry.CommandText pour voir la requête "formée" avec les valeurs avant l'ajout.
    Oui je n'ai qu'une clé primaire, le champ "userid"

  7. #7
    Membre Expert Avatar de _Ez3kiel
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2013
    Messages
    836
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Janvier 2013
    Messages : 836
    Par défaut
    La structure de ta requête paramétrée est étrange ... (Voir pas conventionnel/fonctionnel ) Voir F.A.Q.

    J'ai mis le symbole @ comme préfixe du paramètre mais je ne connais pas celui d'Access ... (Je crois que @ est pour SqlServ et : pour Oracle mais pas sûr ..)

    Si l'Id est Integer, tu devrais remanier le code en conséquence, j'ai fais comme si c'était un String. (Voir commentaires)

    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
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
            Try
     
                Dim cn As New OleDbConnection("PROVIDER=Microsoft.JET.OLEDB.4.0;Data Source =C:\myDB.mdb")
                Dim req As String = "UPDATE [Users] SET password= @pwd WHERE userid= @id ;"
                Dim cmd As New OleDbCommand(req, cn)
                Dim nbLigneAffecte As Integer
     
                Using cn
                    Using cmd
     
                        With cmd.Parameters
                            .Add(New OleDbParameter("@pwd", OleDbType.BSTR))
                            .Add(New OleDbParameter("@id", OleDbType.BSTR)) '<------- A commenter si l'id est un int
     
                            ' .Add(New OleDbParameter("@id", OleDbType.Integer)) '<----- A décommenter si l'id est un int
                        End With
     
     
                        With cmd
                            .Parameters("@pwd").Value = TextBox3.text
                            .Parameters("@id").Value = TextBox1.Text
                        End With
     
                        cn.Open()
                        nbLigneAffecte = cmd.ExecuteNonQuery()
     
                        If nbLigneAffecte >= 1 Then
                            MsgBox("done")
                        Else
                            MsgBox("not done")
                        End If
     
                    End Using
                End Using
     
            Catch ex As Exception
                MsgBox(ex.ToString)
            End Try

  8. #8
    Membre averti
    Profil pro
    Inscrit en
    Février 2013
    Messages
    51
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2013
    Messages : 51
    Par défaut
    Merci _Ez3kiel,

    L'userid et le password sont bien des strings.

    Par contre, j'ai toujours le même message d'erreur, je suis maudis

  9. #9
    Membre Expert Avatar de _Ez3kiel
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2013
    Messages
    836
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Janvier 2013
    Messages : 836
    Par défaut
    Tu as régénéré la solution ?

    A tester si la table [Users] nécessite l'encadrement en crochet ou pas ?
    Msgbox de TextBox3.Text et TextBox1.Text avant l'assignation aux paramètres ?
    Tente la requête "à la main" dans Acess ?

  10. #10
    Membre averti
    Profil pro
    Inscrit en
    Février 2013
    Messages
    51
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2013
    Messages : 51
    Par défaut
    -> J'ai bien (re)généré la solution, en cliquant sur le bouton "play" de Visual Studio, si tu parles bien de cela...

    -> J'ai essayé sans crochets pour la table Users pour tester, pareil.

    -> Msgbox textbox 1 et 3 ok, avant l'assignation des paramètres

    Voici un msgbox de la requête :



    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
           With cmd.Parameters
                            .Add(New OleDbParameter("@pwd", OleDbType.BSTR))
                            .Add(New OleDbParameter("@id", OleDbType.BSTR)) '<------- A commenter si l'id est un int
     
                            ' .Add(New OleDbParameter("@id", OleDbType.Integer)) '<----- A décommenter si l'id est un int
                        End With
     
     
                        With cmd
                            .Parameters("@pwd").Value = TextBox3.Text
                            .Parameters("@id").Value = TextBox1.Text
                        End With
                        MsgBox(cmd.CommandText)
    Étonnant qu'il n'attribue pas les valeurs précédemment données non ?

    Il me reste à tenter la requête dans access...

  11. #11
    Membre Expert


    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2006
    Messages
    970
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Belgique

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

    Informations forums :
    Inscription : Avril 2006
    Messages : 970
    Par défaut
    Étonnant qu'il n'attribue pas les valeurs précédemment données non ?
    Je pense que c'est normal je vérifierais quand j'aurais un peu plus de temps.
    Par contre je continue à m'interroger pour voir si le problème ne viendrais pas du nom de ta table. Peut-être la renommer le temps d'un test ?
    Articles sur les technologies .NET

    Une réponse vous a aidé ? utilisez le bouton

    Votre problème est résolu ? utilisez le bouton

  12. #12
    Modérateur

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    1 722
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 722
    Par défaut
    Bonjour,

    il faut placer password entre crochet

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Using cn As New OleDbConnection("PROVIDER=Microsoft.JET.OLEDB.4.0;Data Source =C:\myDB.mdb"), _
            cmd As New OleDbCommand("UPDATE [Users] SET [password]= ? WHERE userid= ? ;", cn)
    Pour access c'est bien les "?".
    Traductions d'articles :
    La mémoire en .NET - Qu'est-ce qui va où ?
    Architecture DAL de haute performance et DTO ; Version C# : Partie 1,Partie 2,Partie 3 — Version VB.NET : Partie 1,Partie 2,Partie 3
    N'hésitez pas à consulter la FAQ VB.NET, le cours complet de Philippe Lasserre et tous les cours, articles et tutoriels.

  13. #13
    Membre averti
    Profil pro
    Inscrit en
    Février 2013
    Messages
    51
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2013
    Messages : 51
    Par défaut
    Merci rv26t !! ca marche impeccable avec ce code :

    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
     
    Using cn As New OleDbConnection("PROVIDER=Microsoft.JET.OLEDB.4.0;Data Source =C:\myDB.mdb"), _
               cmd As New OleDbCommand("UPDATE [Users] SET [password]= ? WHERE userid= ? ;", cn)
     
                ''# Note: I normally don't use AddWithValue(), but I don't know your data types
                cmd.Parameters.AddWithValue("?", TextBox3.Text)
                cmd.Parameters.AddWithValue("?", TextBox1.Text)
     
                Try
                    cn.Open()
                    cmd.ExecuteNonQuery()
     
                    MsgBox("done")
                Catch ex As Exception
                    MsgBox(cmd.CommandText)
                    MsgBox(ex.ToString)
                End Try
            End Using
    Merci à tous pour votre précieuse aide...

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

Discussions similaires

  1. [MySQL] Problème avec un update
    Par leloup84 dans le forum PHP & Base de données
    Réponses: 22
    Dernier message: 21/09/2006, 10h09
  2. [VBA-A]Problème avec instruction SendKeys
    Par m_haj dans le forum VBA Access
    Réponses: 4
    Dernier message: 27/04/2006, 13h00
  3. Problème avec un update et un champs
    Par kornmuse90 dans le forum Requêtes
    Réponses: 3
    Dernier message: 27/03/2006, 15h55
  4. [VB6] Problème avec requête Update
    Par bb62 dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 02/02/2006, 03h40
  5. problème avec instruction "RemoveItem"
    Par audrey_desgres dans le forum Access
    Réponses: 4
    Dernier message: 15/06/2005, 09h26

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