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

ADO.NET Discussion :

Propriété SelectedValue d'un combobox renvoyant NULL


Sujet :

ADO.NET

  1. #1
    Membre du Club
    Homme Profil pro
    Enseignant
    Inscrit en
    Août 2011
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2011
    Messages : 60
    Points : 47
    Points
    47
    Par défaut Propriété SelectedValue d'un combobox renvoyant NULL
    Salut

    Je n'arrive pas à corriger une erreur due à une valeur NULL renvoyé par la propriété SelectedValue d'un Combobox.

    Je m'explique j'ai une requete Select Multi-Tables SQL qui doit me retourner des valeurs de champs issus de plusieurs tables de ma base de données(la requete marche , je l'ai vérifiée avec SQL Server Studio Management 2008) et se basant sur la valeurs d'un ComboBox , voici le contenu de mes tables :

    eleves(idelv,nom,prenom,#idclasse,...)
    classes(idclasse,nomClasse,nbreEleves,.....)
    matieres(idmat,nomMatiere,typematiere)
    trimestres(idtrim,nomTrim,datedebut,datefin)
    notes(idelv,idmat,idtrim,note)
    les relations entre les tables sont évidentes.

    Voici la requete :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    strSQL = "SELECT eleves.idelv, eleves.nom, eleves.pren, divisions.libcla, matieres.libmat, trimestres.libtrim," & _
     "evaluations.moyev, evaluations.dev1, evaluations.dev2, evaluations.exam, evaluations.moymat FROM eleves " & _
            "INNER JOIN divisions ON eleves.idcla = divisions.idcla INNER JOIN evaluations ON eleves.idelv = evaluations.idelv " & _
            "INNER JOIN trimestres ON evaluations.idtrim = trimestres.idtrim INNER JOIN  matieres ON " & _
            "evaluations.idmat = matieres.idmat WHERE eleves.idcla = '" & cbDiv.SelectedValue.ToString & "' AND" & _
            "evaluations.idmat='" & cbMat.SelectedValue.ToString & "' AND evaluations.idtrim='" & cbTrim.SelectedValue.ToString & "'"
    Cette requete est écrite dans le Form_Load et il me signale cette erreur :
    Object reference not set to an instance of an object.
    Après recherches j'en déduit que la requete me renvoit NULL à cause du SelectedValue des Combobox pourtant les Combobox sont bien remplies par les données issues des tables : classes , matieres et trimestres.

    J'ai crée une procedure pour remplir les Combobox :

    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
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    Private Sub FillCombo()
     
            cn.ConnectionString = strcon
     
            Dim daDiv As New SqlDataAdapter("select idcla,libcla from divisions", cn)
            Dim dsNotes As New DataSet
            Dim dtDiv As DataTable
            dtDiv = dsNotes.Tables("divisions")
     
            If cn.State Then cn.Close()
     
            cn.Open()
     
            daDiv.Fill(dsNotes, "divisions")
            cbDiv.DisplayMember = "libcla"
            cbDiv.ValueMember = "idcla"
            cbDiv.DataSource = dtDiv
     
            cn.Close()
     
            Dim daMat As New SqlDataAdapter("select idmat,libmat from matieres", cn)
            Dim dtMat As New DataTable("matieres")
     
            If cn.State Then cn.Close()
     
            cn.Open()
     
            daMat.Fill(dtMat)
            cbMat.DisplayMember = "libmat"
            cbMat.ValueMember = "idmat"
            cbMat.DataSource = dtMat
     
     
            cn.Close()
     
            Dim daTrim As New SqlDataAdapter("select idtrim,libtrim from trimestres", cn)
            Dim dtTrim As New DataTable("trimestres")
     
            If cn.State Then cn.Close()
     
            cn.Open()
     
            daTrim.Fill(dtTrim)
            cbTrim.DisplayMember = "libtrim"
            cbTrim.ValueMember = "idtrim"
            cbTrim.DataSource = dtTrim
     
            cn.Close()
    Cette procedure est appellée au chargement de la feuille , j'ai beau cherché mais aucun résultat , j'ai fait un test pour récupérer la valeur de selectedValue dans un msgbox et il ne m'affiche rien puis il m'affiche 1 puis 1, c'est à dire il me répète l'affichage du "1" deux fois je n'ai rien compris.

    Merci de m'aider s'il vous plait.

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Citation Envoyé par devman2011 Voir le message
    Après recherches j'en déduit que la requete me renvoit NULL à cause du SelectedValue des Combobox
    Non, la requête ne te renvoie pas null, puisqu'elle n'est jamais exécutée... ça plante sur la création de la requête, parce que si SelectedValue est null (Nothing), tu ne peux pas faire SelectedValue.ToString

    Citation Envoyé par devman2011 Voir le message
    pourtant les Combobox sont bien remplies par les données issues des tables : classes , matieres et trimestres.
    Ce n'est pas parce que les ComboBox sont remplies qu'il y a forcément une valeur sélectionnée... Si tu veux sélectionner le premier élément du ComboBox, mets SelectedIndex = 0 après avoir chargé les données.

  3. #3
    Membre du Club
    Homme Profil pro
    Enseignant
    Inscrit en
    Août 2011
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2011
    Messages : 60
    Points : 47
    Points
    47
    Par défaut
    Merci de votre réponse oui j'ai ajouté :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     ComboBox.SelectIndex =0
    mais ça donne toujours la meme erreur , donc à votre avis est-ce que je peux enlever ToString ou pas ? le problème est : pourquoi SelectValue me renvoi NULL ?

  4. #4
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Citation Envoyé par devman2011 Voir le message
    Merci de votre réponse oui j'ai ajouté :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     ComboBox.SelectIndex =0
    A quel endroit tu as ajouté ça ?

    Citation Envoyé par devman2011 Voir le message
    mais ça donne toujours la meme erreur , donc à votre avis est-ce que je peux enlever ToString ou pas ?
    Bah ça fera plus de NullReferenceException, mais ça marchera pas non plus, puisque la requête générée ne sera pas valide

    Citation Envoyé par devman2011 Voir le message
    le problème est : pourquoi SelectValue me renvoi NULL ?
    Parce qu'il n'y a aucun élément sélectionné

  5. #5
    Membre du Club
    Homme Profil pro
    Enseignant
    Inscrit en
    Août 2011
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2011
    Messages : 60
    Points : 47
    Points
    47
    Par défaut
    Je l'ai ajouté dans la procédure de remplissage des trois combobox : cbDiv(pour le choix des ID de la classe) , cbMat(pour le choix des ID de la matière) et enfin cbtrim(pour le choix des ID du trimestre)

    NB : Dans le code j'ai appellé la table "divisions" au lieu de "classes" pour éviter la confusion avec les mots réservés de VB.NET

    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
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    Private Sub FillCombo()
     
            cn.ConnectionString = strcon
     
            Dim daDiv As New SqlDataAdapter("select idcla,libcla from divisions", cn)
            Dim dsNotes As New DataSet
            Dim dtDiv As DataTable
            dtDiv = dsNotes.Tables("divisions")
     
            If cn.State Then cn.Close()
     
            cn.Open()
     
            daDiv.Fill(dsNotes, "divisions")
            cbDiv.DisplayMember = "libcla"
            cbDiv.ValueMember = "idcla"
            cbDiv.DataSource = dtDiv
            cbDiv.SelectedIndex = 0
     
            cn.Close()
     
            Dim daMat As New SqlDataAdapter("select idmat,libmat from matieres", cn)
            Dim dtMat As New DataTable("matieres")
     
            If cn.State Then cn.Close()
     
            cn.Open()
     
            daMat.Fill(dtMat)
            cbMat.DisplayMember = "libmat"
            cbMat.ValueMember = "idmat"
            cbMat.DataSource = dtMat
            cbMat.SelectedIndex = 0
     
            cn.Close()
     
            Dim daTrim As New SqlDataAdapter("select idtrim,libtrim from trimestres", cn)
            Dim dtTrim As New DataTable("trimestres")
     
            If cn.State Then cn.Close()
     
            cn.Open()
     
            daTrim.Fill(dtTrim)
            cbTrim.DisplayMember = "libtrim"
            cbTrim.ValueMember = "idtrim"
            cbTrim.DataSource = dtTrim
            cbTrim.SelectedIndex = 0
     
            cn.Close()
     
        End Sub
    Vous m'avez dit que la raison pour laquelle SelectedValue me renvoyait NULL c'était parce que rien n'est sélectionné mais avec :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Combobox.SelectedIndex=0
    normalement le premier élément du Combobox est sélectionné au chargement de la feuille mais ça ne donne rien et j'ai oublié de mentionné plus haut que le débogueur me pointe vers le corps de la requete SQL quand il signale l'erreur :

    Object reference not set to an instance of an object.(NullReferenceException was unhandled.

  6. #6
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Bon, je vois pas trop ce qui déconne... j'ai fais un test similaire et chez moi ça marche bien. A quel endroit appelles-tu la méthode FillCombo ? Dans le Load, avant la requête qui plante ?

  7. #7
    Membre du Club
    Homme Profil pro
    Enseignant
    Inscrit en
    Août 2011
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2011
    Messages : 60
    Points : 47
    Points
    47
    Par défaut
    Merci de m'avoir répondu , oui la procédure FillCombo est appellé dans le Form_Load mais une question me ronge : Est-ce que l'évènement SelectedIndexChanged d'un ComboBox s'exécute automatiquement après son remplissage ou bien par une action de l'utilisateur ? car à mon avis s'il s'exécute automatiquement (l'évènement SelectedIndexChanged) après le remplissage du ComboBox via la propriété DataSource alors le temps qu'il affecte ou assigne l'ID de la classe par exemple au SelectValue à l'intérieur de la requete strSQL l'index aura changé de valeur d'où la valeur retourné sera NULL (Nothing) .

  8. #8
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Citation Envoyé par devman2011 Voir le message
    Est-ce que l'évènement SelectedIndexChanged d'un ComboBox s'exécute automatiquement après son remplissage ou bien par une action de l'utilisateur ?
    Les deux, si je me souviens bien... Le fait de changer la DataSource va aussi déclencher l'évènement.

    Citation Envoyé par devman2011 Voir le message
    car à mon avis s'il s'exécute automatiquement (l'évènement SelectedIndexChanged) après le remplissage du ComboBox via la propriété DataSource alors le temps qu'il affecte ou assigne l'ID de la classe par exemple au SelectValue à l'intérieur de la requete strSQL l'index aura changé de valeur d'où la valeur retourné sera NULL (Nothing) .
    Possible... de toutes façons, tu peux toujours forcer l'élément sélectionné avant de faire la requête si tu vois qu'il n'y en a pas (SelectedValue = Nothing ou SelectedIndex = -1)

  9. #9
    Membre du Club
    Inscrit en
    Juillet 2009
    Messages
    106
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 106
    Points : 56
    Points
    56
    Par défaut
    Est-ce que l'évènement SelectedIndexChanged d'un ComboBox s'exécute automatiquement après son remplissage ou bien par une action de l'utilisateur ?
    OUI effectivement un selected indexchanged se declenche par l utilisateur et aussi par le remplissage.
    Pour ton problème t as essayé combo.text?

Discussions similaires

  1. Définir la propriété height d'une combobox
    Par Capitaine Kirk dans le forum Windows Forms
    Réponses: 2
    Dernier message: 24/03/2009, 11h24
  2. Propriété Bookmark d'un ComboBox
    Par Alex Randria dans le forum VB 6 et antérieur
    Réponses: 4
    Dernier message: 24/05/2007, 15h27
  3. propriété style manquante pour combobox
    Par valie dans le forum IHM
    Réponses: 1
    Dernier message: 08/03/2007, 15h21
  4. [C#] proprités text d'une Combobox
    Par kooljy dans le forum Windows Forms
    Réponses: 3
    Dernier message: 29/06/2006, 09h24
  5. [VB6] - Propriété Style d'une ComboBox
    Par jlvalentin dans le forum VB 6 et antérieur
    Réponses: 4
    Dernier message: 15/11/2005, 16h33

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