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 :

Base de donnée et ListBox [Débutant]


Sujet :

VB.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Décembre 2013
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2013
    Messages : 19
    Par défaut Base de donnée et ListBox
    Bonjour a tous. Voila j'ai un problème avec l'affichage de ma base de donnée dans une ListBox. J'ai deux ListBox nommé ListeCLient et ListAffaireClient et aussi un TexteBox1 qui me sert temporairement a me donnée le NumeroCLient de ma ListCLient (c'était pour debogger mon programme).

    Lors du chargement du programme je viens mettre la liste de mes clients via la database dans ma ListBox "ListeCLient". Puis lorsque je clique sur un client quelconque il m'affiche bien les affaires de mon client mais a l'affichage les affaires s'additionne dans ma ListeBox "ListeAffaireClient".

    C'est a dire par exemple, 1er client contient AFF1 puis AFF2, client deux contient AFF3 puis AFF4. Lorsque je clique sur le premier client dans ListeClient, ListeAffaireClient affiche AFF1 et AFF2, puis lorsque je clique sur le deuxième client, il m'affiche AFF3, AFF4, AFF3 et AFF4 qu'alors il n'y en as que deux.Quel serait mon erreur dans mon code que voici



    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
    Private Sub ListeClient_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ListeClient.SelectedIndexChanged
     
            If ListeClient.SelectedIndex <> -1 Then
                TextBox1.Text = CType(ListeClient.SelectedValue, String)
            End If
     
            strSql = "SELECT Affaires.* FROM Affaires"
            ObjetConnection = New OleDbConnection
            ObjetConnection.ConnectionString = strConn
            ObjetConnection.Open()
            ObjetCommand = New OleDbCommand(strSql)
            ObjetDataAdapter = New OleDbDataAdapter(ObjetCommand)
            ObjetCommand.Connection() = ObjetConnection
            ObjetDataAdapter.Fill(ObjetDataSet, "Affaires")
            ObjetDataTable = ObjetDataSet.Tables("Affaires")
     
            Dim i As Integer
     
            For i = 0 To ObjetDataSet.Tables("Affaires").Rows.Count - 1
                ListeClient.SelectedItem = ObjetDataSet.Tables("Affaires").Rows
                ListeAffaireClient.DataSource = ObjetDataSet.Tables("Affaires")
                ListeAffaireClient.DisplayMember = TextBox1.Text
            Next i
        End Sub

    Merci pour votre aide

  2. #2
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 197
    Par défaut
    Citation Envoyé par Loic4891 Voir le message
    Quel serait mon erreur dans mon code
    je ne vois pas trop, je ne suis pas fan des dataset, mais c'est peut le fait que les variables soient utilisées plusieurs fois
    essaye en faisant un nouveau dim sur dataset et datatable

    en tout cas c'est pas génial

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Handles ListeClient.SelectedIndexChanged
    +
    SELECT Affaires.* FROM Affaires
    à chaque clic sur le listbox client tu va chargers toute la table ?

    =>

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select que les colonnes nécessaires si possible from Affaires WHERE IdClient = le client sélectionné dans le listbox client
    ou alors tu charges toute la table une fois (donc pas ici) et tu filtres au moment de la lecture du datatable
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  3. #3
    Membre averti
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Décembre 2013
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2013
    Messages : 19
    Par défaut
    Bonjour et merci pour votre aide voila ce que j'ai actuellement avec mon code voir l'image Description.jpg

    Et voici ce que je souhaite affiché, voir l'image Description2.jpg

    Voici ma base de donnée, voir l'image Description3.jpg

    Et donc je n'arrive a voir ou ce trouve mon erreur ou ce que je ne gère pas mais tous s'ajoute. J'ai essayé d'utiliser la fonction Clear() de ListBox mais il me fait une erreur. Voila
    Images attachées Images attachées    

  4. #4
    Membre averti
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Décembre 2013
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2013
    Messages : 19
    Par défaut
    C'est bon, merci pour votre aide, vous aviez raison sur le faite de cliquer a chaque fois sur ma ListBox ListeClient je rechargeais a chaque fois ma Table et je pense que c'était aussi le problème. J'ai donc remonter quasiment tous mon code dans le Load de ma form et donc il me rest plus que :

    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
    Private Sub ECLogistique_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
     
            strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" & "Data Source= I:\Auto-Entrepreneur\Electro Concept Logistique\Electro Concept Logistique\ECLogistique.mdb;"
            strSql = "SELECT Client.* FROM Client ORDER BY NomSociete ASC"
            ObjetConnection = New OleDbConnection
            ObjetConnection.ConnectionString = strConn
            ObjetConnection.Open()
            ObjetCommand = New OleDbCommand(strSql)
            ObjetDataAdapter = New OleDbDataAdapter(ObjetCommand)
            ObjetCommand.Connection() = ObjetConnection
            ObjetDataAdapter.Fill(ObjetDataSet, "Client")
            ObjetDataTable = ObjetDataSet.Tables("Client")
     
            ListeClient.DisplayMember = "NomSociete" '& "Numerodeclient"
            ListeClient.ValueMember = "Numerodeclient"
            ListeClient.DataSource = ObjetDataSet.Tables("Client")
     
            strSql = "SELECT Affaires.* FROM Affaires"
            ObjetConnection = New OleDbConnection
            ObjetConnection.ConnectionString = strConn
            ObjetConnection.Open()
            ObjetCommand = New OleDbCommand(strSql)
            ObjetDataAdapter = New OleDbDataAdapter(ObjetCommand)
            ObjetCommand.Connection() = ObjetConnection
            ObjetDataAdapter.Fill(ObjetDataSet, "Affaires")
            ObjetDataTable = ObjetDataSet.Tables("Affaires")
     
            ListeAffaireClient.DataSource = ObjetDataSet.Tables("Affaires")
     
         End Sub
     
    Private Sub ListeClient_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ListeClient.SelectedIndexChanged
            If ListeClient.SelectedIndex <> -1 Then
                TextBox1.Text = CType(ListeClient.SelectedValue, String)
            End If
     
            ListeAffaireClient.DisplayMember = TextBox1.Text
        End Sub
    Maintenant pensez vous qu'il serait possible de mettre dans ma ListeBox ListClient deux informations : NomSociete et Numerodeclient séparer par "-". Dans mon code vous verrez j'ai essayé de faire une concaténation mais il me donnais une erreur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ListeClient.DisplayMember = "NomSociete" & "Numerodeclient"

  5. #5
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 197
    Par défaut
    dans le select :
    col 1 & ' ' & col2 as alias


    et dans displaymember mettre alias
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  6. #6
    Membre averti
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Décembre 2013
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2013
    Messages : 19
    Par défaut
    Citation Envoyé par Pol63 Voir le message
    dans le select :
    col 1 & ' ' & col2 as alias


    et dans displaymember mettre alias
    Merci c'est niquel cela fonctionne

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

Discussions similaires

  1. [Débutant] Base de donnée vers ListBox - éléments manquants
    Par microbe83 dans le forum C++Builder
    Réponses: 2
    Dernier message: 19/08/2014, 23h31
  2. listbox lié a une base de données en mode déconnecté
    Par Seth_75 dans le forum Windows Forms
    Réponses: 3
    Dernier message: 15/05/2008, 19h45
  3. Réponses: 5
    Dernier message: 10/01/2008, 08h47
  4. Listbox et base de données
    Par KOUTO dans le forum Delphi
    Réponses: 6
    Dernier message: 08/12/2006, 10h15
  5. Base de données et ListBox
    Par scorpion37 dans le forum C++Builder
    Réponses: 17
    Dernier message: 21/06/2006, 10h23

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