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 :

Datarelation Dataset Gridview


Sujet :

C#

  1. #1
    Membre confirmé
    Inscrit en
    Juillet 2007
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 113
    Par défaut Datarelation Dataset Gridview
    Bonjour tout le monde,

    J'ai un peu lu les documentations sur les Datarelation et je me posais un certain nombre de questions :

    Supposons un Dataset qui possede deux Datatables liees par une datarelation

    - Peut-on requêter sur ces deux Datatables en utilisant la jointure de la DataRelation ?

    - Peut on remplir un DataGridView avec les résultats de cette requête ?

    - Les DataRelation gerent-elles les relations N,N ou doit on créer une DataTable intermediaire ?

    - Peut on faire un parent ou un child sur 3 colonnes ?

    - Ne vaut il mieux pas que je m'oriente vers Link pour faire tout ça ?

    Merci d'avance de vos conseils

  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 : 43
    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
    Par défaut
    Citation Envoyé par BATCHOS CON TEQUILA Voir le message
    - Peut-on requêter sur ces deux Datatables en utilisant la jointure de la DataRelation ?
    Pas exactement... tu peux créer dans une des tables de la relation une colonne calculée (en définissant sa propriété Expression), qui référence la table liée via Parent(nom_de_la_relation) ou Child(nom_de_la_relation). Ensuite tu peux filtrer sur cette colonne...
    Remarque, je n'ai jamais essayé de mettre un "Parent(nom_de_la_relation)" dans un RowFilter, ça marche peut-être...

    Citation Envoyé par BATCHOS CON TEQUILA Voir le message
    - Peut on remplir un DataGridView avec les résultats de cette requête ?
    Oui, en créant des colonnes calculées. Mais comme je l'ai dit avant, ce n'est pas vraiment une requête au sens SQL...

    Citation Envoyé par BATCHOS CON TEQUILA Voir le message
    - Les DataRelation gerent-elles les relations N,N ou doit on créer une DataTable intermediaire ?
    Il faut créer une table intermédiaire

    Citation Envoyé par BATCHOS CON TEQUILA Voir le message
    - Peut on faire un parent ou un child sur 3 colonnes ?
    Oui, tu peux faire des relations sur plusieurs colonnes

    Citation Envoyé par BATCHOS CON TEQUILA Voir le message
    - Ne vaut il mieux pas que je m'oriente vers Link pour faire tout ça ?
    Link ? Tu veux dire Linq ?
    De toutes façons ça ne veut pas dire grand chose... à la base, Linq est une extension du langage, en soit ça ne remplace pas les DataSets (d'ailleurs tu peux faire du "Linq to datasets"). Après il y a des frameworks comme Linq to SQL ou Entity Framework qui remplacent avantageusement les DataSets, il faut voir si ça te convient

  3. #3
    Membre confirmé
    Inscrit en
    Juillet 2007
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 113
    Par défaut
    Bonjour,

    Merci de ta reponse

    J ai commence a m orienter sur ta premiere reponse :

    Je bloque sur

    ....qui référence la table liée via Parent(nom_de_la_relation) ou Child(nom_de_la_relation). Ensuite tu peux filtrer sur cette colonne...

    En utilisant la propriete expression j'arrive a faire une colonne calculee a partir des colonnes de la meme datatable

    Je n arrive pas a utiliser ma datarelation pour aller chercher une colonne d un autre datatable

    As tu un lien a me conseiller ?
    Ou un petit bout de code ?

    Merci d avance de ton aide

  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 : 43
    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
    Par défaut
    Par exemple, considère le dataset suivant :


    La colonne Livre.NomAuteur est définie comme expression pour aller chercher le nom de l'auteur via la relation :
    Expression = "Parent(Auteur_Livre).Nom"

    Ensuite tu peux utiliser cette colonne dans un filtre comme n'importe quelle autre colonne de la table

  5. #5
    Membre confirmé
    Inscrit en
    Juillet 2007
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 113
    Par défaut
    Bonsoir

    Merci de tes precisions

    Mais mon compilateur n aime pas ma syntaxe.

    Voici ce que j'ai fait :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
     
    DataRelation Drel = new DataRelation("Rel", dataSet1.Tables[0].Columns["JOINTURE"], dataSet1.Tables[1].Columns["IDPRODUIT"], true);
    dataSet1.Relations.Add(Drel);
    dataSet1.Tables[0].Columns["JOINTURE"].Expression = "Parent(Rel).IDPRODUIT";
    J ai le droit a : CANNOT FIND RELATION Rel

    Et si j essaie :

    dataSet1.Tables[0].Columns["JOINTURE"].Expression = "Child(Rel).IDPRODUIT";

    Il me jette un Cannot interpret Token Child

    Je ne sais plus quoi faire et toutes mes recherches sont infructueuses

    Aurais tu une piste ou un conseil a me donner ?

    Merci encore

  6. #6
    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 : 43
    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
    Par défaut
    Il y a un truc qui ne colle pas... ta colonne JOINTURE sert dans la définition de la relation, donc tu ne peux pas lui coller une expression... Fais voir le schema de tes tables, en indiquant quel est le critère de jointure

  7. #7
    Membre confirmé
    Inscrit en
    Juillet 2007
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 113
    Par défaut
    Bonjour,

    Encore merci de tes réponsesL

    J'ai refais mes tests.

    Je suis parti sur des données plus cohérentes

    En pièce jointe, il y a l'image

    J'ai deux tables : Clients et Produits

    La jointure se fait sur la colonne IDCLIENT

    Ce qui se trouve dans la ListBox provient de ce 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
     
    dataGridView1.DataSource = this.dataSet1;
    dataGridView1.DataMember = "Clients";
     
    dataGridView2.DataSource = this.dataSet1;
    dataGridView2.DataMember = "Produits";
     
    DataRelation dr = new DataRelation("Relation", this.dataSet1.Tables["Clients"].Columns["IDCLIENT"], this.dataSet1.Tables["Produits"].Columns["IDCLIENT"]);
     
    dataSet1.Relations.Add(dr);
     
    foreach (DataRow row in this.dataSet1.Tables["Clients"].Rows)
    {
        DataRow[] Dr_rel = row.GetChildRows("Relation");
        listBox1.Items.Add(Dr_rel[0].ItemArray[1].ToString());
    }
    Jusque là tout va bien.

    Maintenant, je fais :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    dataSet1.Tables["Produits"].Columns["IDCLIENT"].Expression = "Parent(relation).IDCLIENT";
    et le compilo me dit :

    Impossible de définir la propriété Expression sur la colonne IDCLIENT, car elle fait partie d'une contrainte.

    Je comprends le message d'erreur mais la résolution, je ne vois pas

    Merci encore
    Images attachées Images attachées  

  8. #8
    Membre confirmé
    Inscrit en
    Juillet 2007
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 113
    Par défaut
    Bonjour,

    Après mes différents tests, j'ai réussi à faire quelque chose d'intéressant.

    Je mets ici le bout de 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
     
    //Instancier la DataRelation
    DataRelation dr = new DataRelation("Relation", this.dataSet1.Tables["Clients"].Columns["IDCLIENT"], this.dataSet1.Tables["Produits"].Columns["IDCLIENT"], false);
    dataSet1.Relations.Add(dr);
     
    dataSet1.Tables["Produits"].Columns["IDCLIENT"].Expression = "Parent(relation).IDCLIENT";
     
    //Afficher dans une colonne de la table Child, le nom des acheteurs respectifs
    dataSet1.Tables["Produits"].Columns.Add("Acheteurs", typeof(string), "Parent(Relation).RAISON_SOCIALE");
     
    //Afficher dans un 3eme GridView les résultats d'une requete
    DataRow[] copyRows = dataSet1.Tables["Produits"].Select("Parent(relation).IDCLIENT = 0");
    foreach (DataRow copyRow in copyRows) 
    {
                    DataRow newRow;
                    newRow = dataSet2.Tables["Clients"].NewRow();
                    newRow["RAISON_SOCIALE"] = copyRow["ACHETEURS"].ToString();
                    newRow["PRODUIT_ACHETE"] = copyRow["DENOMINATION"].ToString();
                    dataSet2.Tables["Clients"].Rows.Add(newRow);
                }     
     
                dataGridView3.DataSource = this.dataSet2;
                dataGridView3.DataMember = "Clients";
    Si tu vois mieux, n'hésite pas à me le signaler

    NB : Cette ligne n'est manifestement pas indispensable :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    dataSet1.Tables["Produits"].Columns["IDCLIENT"].Expression = "Parent(relation).IDCLIENT";
    Je continue mes tests et je posterai mes résultats ici.

  9. #9
    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 : 43
    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
    Par défaut
    Je ne comprends pas pourquoi tu essaies de mettre une expression sur la colonne qui fait la jointure, ca n'a pas de sens... La propriété Expression sert à créer des colonnes "calculées" en fonction des autres colonnes de la table et des tables liées. Dans la colonne de jointure, tu as déjà des données (sinon tu ne pourrais pas faire la jointure), il n'y a rien à calculer...

    Ce que tu veux, c'est juste afficher dans le DGV du bas les produits du client séléctionné dans le DGV du haut ? Dans ce cas, le plus simple est a priori de passer par le designer, qui va te faire ça proprement en passant par une BindingSource. Tu définis comme source de données du premier DGV la table clients, et comme source du second DGV tu mets la relation. Le designer se charge de créer les BindingSource qui vont bien, et il n'y a rien d'autre à gérer, c'est automatique

    Si tu veux le faire par le code, ça doit donner quelque chose comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    BindingSource bsClients = new BindingSource(dataSet1, "Clients");
    BindingSource bsProduits = new BindingSource(bsClients, "Relation");
    dataGridViewClients.DataSource = bsClients;
    dataGridViewProduits.DataSource = bsProduits;
    (en supposant que tu aies déjà créé la relation)

  10. #10
    Membre confirmé
    Inscrit en
    Juillet 2007
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 113
    Par défaut
    Bonjour,

    Désolé du temps de réponse.

    Je mets ce post en résolu car tout fonctionne maintenant

    Encore merci

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

Discussions similaires

  1. dataset, gridview et webservice (2)
    Par Nicopilami dans le forum ASP.NET
    Réponses: 0
    Dernier message: 21/09/2009, 09h31
  2. dataset, gridview et webservice
    Par Nicopilami dans le forum ASP.NET
    Réponses: 8
    Dernier message: 18/09/2009, 16h58
  3. [Vb.Net]_DataGridView, DataSet, DataRelation ?
    Par Gdal dans le forum VB.NET
    Réponses: 5
    Dernier message: 22/03/2007, 11h07
  4. [2.0][VB.Net]_Renseignement DataRelation DataSet MAJ Access ?
    Par Gdal dans le forum Accès aux données
    Réponses: 2
    Dernier message: 07/11/2006, 22h21
  5. [C#|Gridview|Dataset] Remplir Gridview
    Par dumser1 dans le forum Windows Forms
    Réponses: 20
    Dernier message: 16/02/2006, 13h01

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