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

Table de hachage (hastable) VB.net


Sujet :

Windows

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2009
    Messages
    90
    Détails du profil
    Informations personnelles :
    Localisation : France, Marne (Champagne Ardenne)

    Informations forums :
    Inscription : Octobre 2009
    Messages : 90
    Par défaut Table de hachage (hastable) VB.net
    Bonjourà tous,
    Voila j'ai commencé la création d'une table de hachage pour récuperer l'index_Agent (qui se trouve être une clé primaire d'une table) afin d'alimenter une listebox etd'éviter les homonymes.
    Le probème c'est que je n'arrive pas à terminer la table de hachage si quelqu'un pouvait m'aider ce serait super sympa. Voici le 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
    Dim NbEnreg 
    Me.Tbl_AgentsTableAdapter.Fill(Me.GRHDataSet1.Tbl_Agents) 
    Me.objDATA = New CLdata() 
    Me.rqSql = "SELECT Index_Agent, Nom, Prenom " & _ 
    "FROM Tbl_Agents " 
    Me.DS = Me.objDATA.getRows(Me.rqSql, "TBL_CHOIX_AGENT") 
    NbEnreg = DS.Tables(0).Rows.Count - 1 
    For I = 0 To NbEnreg 
    H.Add(DS.Tables(0).Rows(I).Item(0), DS.Tables(0).Rows(I).Item(1)) 
    Me.search.Items.Add(DS.Tables(0).Rows(I).Item(1) & " " & DS.Tables(0).Rows(I).Item(2)) 
    Next 
    End Sub 
    
    Private Sub search_SelectedIndexChanged_1(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles search.SelectedIndexChanged 
    
    Me.search.SelectedIndex 
    Call Me.searchDATA() 
    End Sub

    J'ai du mal à savoir quoi mettre dans me.search.selectedIndex

    search est le nom de la listbox

    Voila et merci d'avance

  2. #2
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 398
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 398
    Par défaut

    Je suis peut-être aveugle, mais je ne vois pas de table de hachage ici: seulement des tables de base de données...

    De plus, les System.Collections.HashTable sont obsolètes: Il est préférable d'utiliser les System.Collections.Generic.Dictionary(Of TKey, TValue)...
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2009
    Messages
    90
    Détails du profil
    Informations personnelles :
    Localisation : France, Marne (Champagne Ardenne)

    Informations forums :
    Inscription : Octobre 2009
    Messages : 90
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    H.Add(DS.Tables(0).Rows(I).Item(0), DS.Tables(0).Rows(I).Item(1)) 
    Me.search.Items.Add(DS.Tables(0).Rows(I).Item(1) & " " & DS.Tables(0).Rows(I).Item(2))
    c'est une hashtable

  4. #4
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 398
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 398
    Par défaut
    Tu veux dire que H est une System.Collections.HashTable ?

    Tu cherches à obtenir quoi en fonction de quoi exactement?
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2009
    Messages
    90
    Détails du profil
    Informations personnelles :
    Localisation : France, Marne (Champagne Ardenne)

    Informations forums :
    Inscription : Octobre 2009
    Messages : 90
    Par défaut
    Oui dans mes déclarations du formulaire Private H as new Hashtable

    En gros j'ai une listeBox, ou j'affiche le nom et le prénom des employés et je souhaite que quand je clic sur un nom prénom de la listebox les informations des agents s'affichent dans les différentes textBox prévu à cette effet.

    J'ai utilisé le système de table de hachage pour éviter les homonymies je m'explique.

    En fait dans ma Hashtable je met en en clé le nom et le prenom de chacun des employés et comme valeur l'index qui est dans ma table donc comme cela chaque nom et prénom sera associé à l'index de ma table sous sql server 2005 et l'homonymie n'existera plus.

  6. #6
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 398
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 398
    Par défaut
    Il te faudrait plutôt un truc de ce genre:
    Code VB : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    	Structure NomPrenom
    		Public nom As String
    		Public prenom As String
     
    		Public Sub New(ByVal nom As String, ByVal prenom As String)
    			Me.nom = nom
    			Me.prenom = prenom
    		End Sub
    	End Structure
     
    	Private H As New Dictionary(Of NomPrenom, Integer)
     
    ...
    	'Dans ta boucle
    		H.Add(New NomPrenom(nom, prenom), id)
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 19/03/2007, 10h34
  2. table de hachage
    Par mrtatou dans le forum Langage
    Réponses: 4
    Dernier message: 18/01/2006, 09h41
  3. Table de hachage
    Par Gryzzly dans le forum Algorithmes et structures de données
    Réponses: 1
    Dernier message: 25/12/2005, 17h31
  4. [Conception] Table de hachage et doublons de clés
    Par mammou dans le forum Collection et Stream
    Réponses: 2
    Dernier message: 13/05/2004, 19h16
  5. Réponses: 2
    Dernier message: 05/02/2004, 12h54

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