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 :

ExecuteNonQuery : la propriété Connection n'a pas été initialisée.


Sujet :

VB.NET

  1. #1
    Membre habitué
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2011
    Messages
    255
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Octobre 2011
    Messages : 255
    Points : 193
    Points
    193
    Par défaut ExecuteNonQuery : la propriété Connection n'a pas été initialisée.
    Bonjour a tous,

    Comme je l'ai mentionné dans le titre j'ai eu erreur
    ExecuteNonQuery : la propriété Connection n'a pas été initialisée.
    quand j’exécute ma fonction :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
        Public connectionString As String = "Data Source=JEROME-PC\SQLEXPRESS;Initial Catalog=MonAlbum;Integrated Security=True"
     
       Public Sub OuvrirConnexion()
            Dim connexion As SqlConnection = New SqlConnection(connectionString)
            connexion.Open()
        End Sub
        Public Sub FermerConnexion()
            Dim connexion As SqlConnection = New SqlConnection(connectionString)
            connexion.Close()
        End Sub
    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
     
        Public Sub AjouterUtilisateur(ByVal newUser As MonAlbumLibrairie.Utilisateur) Implements ImyService.AjouterUtilisateur
     
            Dim query As String
            query = "INSERT INTO utilisateur (nom, prenom,adresse,idNiveau,pseudo,password) "
            query += "VALUES (@nom,@prenom,@adresse,@idNiveau,@pseudo,@password)"
     
            Dim cxString As New SqlConnection("Data Source=JEROME-PC\SQLEXPRESS;Initial Catalog=MonAlbum;Integrated Security=True")
            Dim commande As SqlCommand = New SqlCommand(query)
            OuvrirConnexion()
            With commande.Parameters
                .Add("@nom", SqlDbType.NVarChar, 50)
                .Add("@prenom", SqlDbType.NVarChar, 50)
                .Add("@adresse", SqlDbType.VarChar)
                .Add("@idNiveau", SqlDbType.Int)
                .Add("@pseudo", SqlDbType.VarChar, 15)
                .Add("@password", SqlDbType.VarChar, 10)
            End With
     
            With commande
                .Parameters("@nom").Value = newUser.nom
                .Parameters("@prenom").Value = newUser.prenom
                .Parameters("@adresse").Value = newUser.adresse
                .Parameters("@idNiveau").Value = newUser.idNiveau
                .Parameters("@pseudo").Value = newUser.pseudo
                .Parameters("@password").Value = newUser.password
            End With
     
            OuvrirConnexion()
            commande.ExecuteNonQuery()
            FermerConnexion()
        End Sub
    Merci de votre aide

  2. #2
    Membre émérite Avatar de meziantou
    Homme Profil pro
    Ingénieur R&D
    Inscrit en
    Avril 2010
    Messages
    1 223
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : Canada

    Informations professionnelles :
    Activité : Ingénieur R&D
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2010
    Messages : 1 223
    Points : 2 439
    Points
    2 439
    Par défaut
    Le problème est que tu n'utilises pas la connexion que tu ouvres.
    Il faut faire quelque chose comme
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Dim connexion As New SqlConnection("Data Source=JEROME-PC\SQLEXPRESS;Initial Catalog=MonAlbum;Integrated Security=True")
    connexion.Open()
    Dim commande As SqlCommand = New SqlCommand(query, connexion)

  3. #3
    Expert éminent sénior Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 176
    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 176
    Points : 25 118
    Points
    25 118
    Par défaut
    ou faire commande.connection = mavariableconnection

    rien n'est implicite, il n'y a pas une connexion par application, il peut même y avoir plusieurs connexions ouvertes sur des bases différentes, c'est pour ca qu'il est normal de dire à un command (requete) où il doit s'exécuter

  4. #4
    Membre habitué
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2011
    Messages
    255
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Octobre 2011
    Messages : 255
    Points : 193
    Points
    193
    Par défaut
    Ah oui effectivement, mais ou avais-je la tête

    Merci a vous deux.

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

Discussions similaires

  1. Réponses: 7
    Dernier message: 24/04/2012, 19h02
  2. Réponses: 2
    Dernier message: 25/05/2010, 20h27
  3. Réponses: 19
    Dernier message: 17/05/2010, 22h54
  4. Réponses: 9
    Dernier message: 07/10/2009, 16h30
  5. Réponses: 12
    Dernier message: 22/08/2009, 18h16

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