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 :

[C#] Comment trier une DataTable ?


Sujet :

C#

  1. #1
    Membre régulier Avatar de royto
    Homme Profil pro
    Développeur .Net & Web
    Inscrit en
    Mai 2005
    Messages
    92
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur .Net & Web

    Informations forums :
    Inscription : Mai 2005
    Messages : 92
    Points : 96
    Points
    96
    Par défaut [C#] Comment trier une DataTable ?
    Bonjour,

    je recupere des données de 2 bases differentes dans 2 dataTables. Ils contiennent 2 colonnes de meme nom descript et identifiant.
    Je fusionne ensuite mes dataTables.

    Je veux ensuite les trier.
    J'utilise pour cela une datatable qui je remplit par les row que j'ai recuperé de ma datatable fusionné en ayant effectue un select avec mon tri mais ca ne marche pas. J'obtiens en resultat une datatable mais les données sont toujours trié de la meme facon qu'apres la fusion.

    Voici mon 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
    19
    20
    21
    22
    23
    24
     
     
    //Fusion des datatables
    DataRow dr;
    object[] o = new object[dt2.Columns.Count];
    for(int i=0;i<dt2.Rows.Count;i++)
    {
    	dr = dt2.Rows[i];
    	for (int j=0;j<dr.ItemArray.Length;j++)
    		o[j] = dr.ItemArray.GetValue(j);
     
    dt.Rows.Add(o);
    }
     
    dt.Columns[0].ColumnName = "descript";
     
    DataTable dtClone = new DataTable();
     
    dtClone.Columns.Add( "descript", typeof(string) );
    dtClone.Columns.Add( "value", typeof(string) );
     
    DataRow[] rows = dt.Select("", "descript ASC");
    foreach (DataRow row in rows)
    	dtClone.ImportRow(row);
    Merci

  2. #2
    Expert éminent
    Avatar de neguib
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 627
    Détails du profil
    Informations personnelles :
    Âge : 64
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 627
    Points : 7 879
    Points
    7 879
    Par défaut
    Tu disposes de la Classe DataView
    Citation Envoyé par MSDN
    Représente une vue de DataTable personnalisée pouvant faire l'objet de liaisons de données
    pour le tri, la recherche, la modification et la navigation.

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    147
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 147
    Points : 155
    Points
    155
    Par défaut
    Est ce que tu ne peux pas gérer ca au niveau de ta requête ?
    (à supposer que tu fasses bien une requête)

    Avec une jointure genre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT mabase1.champ1, mabase1.champ2, mabase2.champ1
    FROM maTable1
    INNER JOIN maTable2
    ON maTable1.descript = maTable2.identifiant
    ORDER BY ce_que_tu_veux_pour_ton_tri
    Vu que d'après ce que j'ai compris les champs descript et identifiant correspondent ...

    Ensuite quand ca arrive dans tes DataTable / DataRow / DataSet, y sont déjà triés, sachant que les tri par les SGBD sont mieux optimisés que les tris que les tris fait soi meme au niveau client.

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 13/07/2006, 22h18
  2. [C#]Comment trier une collection?
    Par Cube55 dans le forum Windows Forms
    Réponses: 6
    Dernier message: 06/06/2006, 19h18
  3. Réponses: 7
    Dernier message: 10/05/2006, 11h15
  4. Comment trier une table paradox dans un Ttable sur un Dbgrid
    Par amireve dans le forum Bases de données
    Réponses: 5
    Dernier message: 26/12/2005, 19h28
  5. Comment trier une DBGRID en cliquant sur une colonne
    Par sessime dans le forum Bases de données
    Réponses: 8
    Dernier message: 09/10/2004, 16h18

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