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

C# Discussion :

Distinct sur Tables ou listes


Sujet :

C#

  1. #1
    Membre émérite
    Profil pro
    Mangeur de gauffre
    Inscrit en
    Octobre 2007
    Messages
    4 413
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Mangeur de gauffre

    Informations forums :
    Inscription : Octobre 2007
    Messages : 4 413
    Points : 2 498
    Points
    2 498
    Par défaut Distinct sur Tables ou listes
    Bonjour

    Je sais que l'on peut mettre des filtre sur un Bindingsource

    Mais peux-t-on faire un distinct ?

    La réponse est : Non (merci TomLev)

    Pour faire un distinct sur une DataTable, tu peux passer par une DataView, par exemple :

    Code :
    DataView view = new DataView(table);
    DataTable distinctTable = view.ToTable(true, "nomColonne1", "nomColonne2");
    Mais on peut aussi Faire un List.Distinct(Comparer)

    Je me demande ce qui est le plus performant

    Passer par une datatable est sans doute plus simple a l'ecriture mais plus lourd pour la gestion interne.

    ??

  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 753
    Points
    39 753
    Par défaut
    Citation Envoyé par olibara Voir le message
    Je me demande ce qui est le plus performant
    Ca dépend... Si tu fais un distinct sur 2 colonnes d'une datatable, ça va plus vite que si tu le fais sur 30 colonnes. De la même façon, avec la méthode d'extension Distinct, ça dépend de la complexité du IEqualityComparer<T> utilisé. Donc il n'y a pas vraiment de réponse unique à cette question, et il n'y a pas vraiment une solution meilleure que l'autre : utilise celle qui correspond le mieux à ton besoin (a priori le DataView si tu travailles avec des DataSets)

  3. #3
    Membre émérite
    Profil pro
    Mangeur de gauffre
    Inscrit en
    Octobre 2007
    Messages
    4 413
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Mangeur de gauffre

    Informations forums :
    Inscription : Octobre 2007
    Messages : 4 413
    Points : 2 498
    Points
    2 498
    Par défaut
    Salut

    En fait j'essaye de trouver la maniere la plus souple pour resoudre un truc pas vraiment simple

    1- J'ai une datatable contenant Pays,Regions,Produit
    2- Bien entendu cette table est un produit cartesion de Pays x regions x produits
    3- Je veux permettre a l'utilisateur de choisir comme il le souhaite dans trois combos (Pays, Region, Produit)

    a) Un pays
    b) Une region,
    c) Un produit

    Bien entendu il peut le faire dans l'ordre qu'i veut !!

    Je souaite evidement que les combos proposent les element DISTINCT

    A chaque selection d'un element les deux autres combos doivent etre filtres

    On peut evidement lever le filtre genere par un combo

    J'hésite encore sur la methode de levée de filtre
    1- Un bouton reset par combo
    2- soit en reselectionnant dans le combo concerné

    Donc je cherche un peu

    Je pense a faire

    1- Une dadatable matrice
    2- Trois datatable dediées a chaque combo

    Les datatables dédiées seraient issues d'un Distinct + filtre a partir de dataview sur la datatable matrice

  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 753
    Points
    39 753
    Par défaut
    Citation Envoyé par olibara Voir le message
    1- J'ai une datatable contenant Pays,Regions,Produit
    2- Bien entendu cette table est un produit cartesion de Pays x regions x produits
    Si je comprends bien, cette jointure provient d'une jointure cartésienne entre 3 tables de la bdd ? Dans ce cas, pourquoi ne pas les charger dès le départ dans 3 DataTable séparés ? D'ailleurs, à quoi sert ce produit cartésien ?

  5. #5
    Membre émérite
    Profil pro
    Mangeur de gauffre
    Inscrit en
    Octobre 2007
    Messages
    4 413
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Mangeur de gauffre

    Informations forums :
    Inscription : Octobre 2007
    Messages : 4 413
    Points : 2 498
    Points
    2 498
    Par défaut
    Bonjour Tomlev

    Oui tu a raison ! je pourrais charger trois tables et gerer les filtres via des DataView sur chacune

    C'est peut etre finalement la meilleure solution pour le distinct
    Reste a gerer les filtres

    Cette solution inverse la mecanique

    Plutot que d'avoir un dataview filtré sur une table pour generer trois tables secondaires
    Je maintiendrais trois tables primaires et trois dataview filtrés

Discussions similaires

  1. Liste déroulante XL sur table Access
    Par curt dans le forum Excel
    Réponses: 3
    Dernier message: 01/08/2008, 11h35
  2. Liste DISTINCT sur plusieur table
    Par Nako_lito dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 19/06/2008, 08h49
  3. Réponses: 7
    Dernier message: 09/09/2007, 19h27
  4. Réponses: 3
    Dernier message: 13/04/2007, 16h00
  5. Réponses: 7
    Dernier message: 24/01/2007, 22h54

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