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

Windows Forms Discussion :

[VB.Net] Utilisation de ExecuteNonQuery()


Sujet :

Windows Forms

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Mai 2009
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2009
    Messages : 2
    Points : 2
    Points
    2
    Par défaut [VB.Net] Utilisation de ExecuteNonQuery()
    Bonjour à tous,

    J'ai un problème avec l'utilisation de la commande ExecuteNonQuery()
    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
     
    Dim cn As New OleDbConnection
    Dim dte As Date = Date.Today
    Dim strcon As String = "Provider=Microsoft.Jet.OLEDB.4.0; " & "Data Source=../../../../Compte.mdb;"
     
    cn.ConnectionString = strcon
    cn.Open()
     
    Dim cmd As OleDbCommand
    cmd = cn.CreateCommand
    cmd.CommandText = "INSERT INTO OBJET (DateObjet, TxtObjet) VALUES (" & dte.Date & ",Test)"
    cmd.ExecuteNonQuery()
    L'affaire est que la connection est bien établie mais lorsque j'arrive à "cmd.ExecuteNonQuery()" le débogueur m'informe que :
    "Aucune valeur donnée pour un ou plusieurs des paramètres requis."

    J'ai cherché dans l'aide en ligne et un peu partout sur internet mais je ne comprend vraiment pas pourquoi ca ne fonctionne pas ! ..

    Merci de votre aide !

  2. #2
    Expert éminent
    Avatar de StormimOn
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2005
    Messages
    2 593
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Sarthe (Pays de la Loire)

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

    Informations forums :
    Inscription : Mai 2005
    Messages : 2 593
    Points : 7 660
    Points
    7 660
    Par défaut
    Le message d'erreur indique un problème dans ta requête. TxtObjet étant un champ de type texte (à priori en tout cas), il faut mettre la chaîne entre quote.

    Essaye avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    cmd.CommandText = "INSERT INTO OBJET (DateObjet, TxtObjet) 
      VALUES (" & dte.Date & ",'Test')"
    en supposant que la date soit correctement formatée, sinon tu auras aussi une erreur.

    Pour éviter ce genre de désagrément, il vaut mieux utiliser des requêtes paramétrées.
    Pas de questions techniques par MP

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Mai 2009
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2009
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    Yeah Merci beacoup pour la rapidité et la précision ^^ ca fonctionne nikel

    Je vais me pencher sur les requêtes paramétrées mais ca me semble plus compliqué d'utilisation !

  4. #4
    Expert éminent
    Avatar de StormimOn
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2005
    Messages
    2 593
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Sarthe (Pays de la Loire)

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

    Informations forums :
    Inscription : Mai 2005
    Messages : 2 593
    Points : 7 660
    Points
    7 660
    Par défaut
    Citation Envoyé par AcidX Voir le message
    Je vais me pencher sur les requêtes paramétrées mais ca me semble plus compliqué d'utilisation !
    Ca semble, mais c'est tout. Pour le reste ça éliminera beaucoup de soucis, comme penser à doubler les quotes dans les chaînes de caractères par exemple. Avec les requêtes paramétrées tout ça est géré par .Net.
    Pas de questions techniques par MP

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

Discussions similaires

  1. [VB.NET] Utilisation d'ocx
    Par zen_ dans le forum Windows Forms
    Réponses: 10
    Dernier message: 29/05/2006, 09h35
  2. [VB.NET] Utilisation des sessions dans Session_End ?
    Par San Soussy dans le forum ASP.NET
    Réponses: 2
    Dernier message: 02/02/2005, 16h40
  3. [VB.NET] Utiliser les collections de contrôles (Textbox)
    Par dinbougre dans le forum Windows Forms
    Réponses: 3
    Dernier message: 09/01/2005, 18h57
  4. [VB.NET] Utiliser un fichier udl
    Par HULK dans le forum Windows Forms
    Réponses: 7
    Dernier message: 01/12/2004, 11h14
  5. [.NET] Utiliser MSN Messenger ds une appli
    Par Thomas Lebrun dans le forum Général Dotnet
    Réponses: 3
    Dernier message: 02/04/2004, 16h58

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