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#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  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

+ 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