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 :

Recherche dans une liste tres lente


Sujet :

VB.NET

  1. #1
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Décembre 2008
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2008
    Messages : 126
    Points : 94
    Points
    94
    Par défaut Recherche dans une liste tres lente
    Bonjour, j'ai un probleme d'optimisation.
    J'ai une liste d'objet (A) et une liste d'Objet (B). Chaque object A possedent un champ d'un objet de la liste d'objet (B) (une cle etrangere).

    Actuellement, lorsque je veux recuperer l'objet B correspondant au lien de l'objet A, j'ai
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    FOR EACH objb in listOfB
             if objb.monchamp = obja.monchamp then
                  return objb
             end if
    NEXT
    Le probleme c'est que j'ai 450000 objet A et 32000 objet B
    La requete est vraiment longue

    Comment puis-faire pour amelirorer cette requete?

    Merci d'avance

  2. #2
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    94
    Détails du profil
    Informations personnelles :
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Juillet 2008
    Messages : 94
    Points : 95
    Points
    95
    Par défaut
    Bonjour,

    Si ta liste est triée, tu peux faire une recherche dichotomique.

    Sinon, tu parles de requête. Tes objets sont en base de données ?
    Si c'est le cas, il faut mieux que la base de données te retourne directement le bon résultat. Ce sera plus rapide.

  3. #3
    Membre expérimenté
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2006
    Messages
    1 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Argentine

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 173
    Points : 1 418
    Points
    1 418
    Par défaut
    monchamp est de quel type ?

  4. #4
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Décembre 2008
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2008
    Messages : 126
    Points : 94
    Points
    94
    Par défaut
    Monchamp est une string (lettre et chiffre).
    En ce qui concerne l'acces BD, j'y ai pense mais je me demandais si il n'y avait pas moyem de le faire en memoire puisque de toute facon les objet y sont

  5. #5
    Membre expérimenté
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2006
    Messages
    1 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Argentine

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 173
    Points : 1 418
    Points
    1 418
    Par défaut
    essaye avec .equals()

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    94
    Détails du profil
    Informations personnelles :
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Juillet 2008
    Messages : 94
    Points : 95
    Points
    95
    Par défaut
    Il est possible de le faire sans passer par une nouvelle requête, mais ce sera très dur de faire plus rapide que celle-ci. Les bases de données sont optimisées pour les recherches.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "Select * from TableObjB WHERE TableObjB.monChamp = " & obja.monchamp
    Sinon, comment récupères-tu tes objets au départ. Si c'est par une requête qui récupère tous les objets, tu peux les trier par ordre de monChamp, ta liste sera alors triés par ordre alphabétique sur ce champ. Tu pourras alors utilisé la recherche dichotomique.

    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
     
    Private function rechercherObject(byval objectA as Object, listOfB as list(object), byval indexDep as Integer, byval indexFin as Integer) as Object
    ' tester objet du milieu
    Dim taille as integer = indexFin + 1 - indexDep
    if taille <= 0 then
    return Nothing
    end if
     
    Dim milieu as integer
    if taille mod 2 = 1
    milieu =(taille  - 1) / 2
    else
    milieu = (taille  / 2)
    End if
    Dim objectB as Object = listOfB.item(milieu)
     
    If objectB .monChamp < objectA.monChamp Then
    return rechercherObject(objectA, listOfB, indexDep, milieu -1)
    Elseif objectB .monChamp = objectA.monChamp Then
    return objectB
    Else
    return rechercherObject(objectA, listOfB, milieu + 1, indexFin)
    End if
     
    End Function
    Ton appel initial sera :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    rechercherObject(objectA, listOfB, 0, listOfB.count - 1)
    Autre point, si ton but est de seulement de récupérer tes objectA et de tous les relier avec les objectsB correspondants, pourquoi ne pas faire une jonction dans ta requête initiale, afin de récupérer en même temps les objets A et B.

  7. #7
    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
    voir si un system.collections.generic.dictionary(of ) est utilisable dans ton cas (il utilise une dichotomie sur les recherches par clés)

    sinon au lieu dans l'objet A de mettre la valeur de l'objet B, met l'objet B directement !!

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

Discussions similaires

  1. [VBA-Excel] Effectuer une recherche dans une liste view
    Par Miles Raymond dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 23/11/2006, 17h21
  2. Imposer une methode Equals pour une recherche dans une List
    Par petozak dans le forum Débuter avec Java
    Réponses: 5
    Dernier message: 03/10/2006, 10h41
  3. Réponses: 2
    Dernier message: 07/07/2006, 10h00
  4. Réponses: 2
    Dernier message: 10/10/2005, 02h25
  5. Recherche dans une liste non trié
    Par Oberown dans le forum Algorithmes et structures de données
    Réponses: 7
    Dernier message: 13/09/2004, 13h56

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