laurent180
Messages postés72Date d'inscriptionvendredi 4 avril 2003StatutMembreDernière intervention 2 novembre 2008
-
5 févr. 2008 à 15:44
yboisdon
Messages postés1Date d'inscriptionmercredi 23 février 2005StatutMembreDernière intervention29 mai 2009
-
29 mai 2009 à 11:08
Bonjour,
J'aimerai savoir si qq a un exemple. Je n'arrive pas a afficher une relation de table.
j'ai ma 1 table "client" et ma 2 table "facture"
et j'aimerai lorsque je selectionne un client avoir directement la liste des factures qui si rapporte.
je travail en mode deconnecté.
j'arrive a affiché le client mais pas les facture.
Si qq a un exemple je suis preneur.
imothepe_33
Messages postés168Date d'inscriptionmardi 27 juillet 2004StatutMembreDernière intervention28 novembre 20127 7 févr. 2008 à 15:20
Si tu boss en mode déconnecté cela veut dire que tu utilise un Dataset.
- Tout d'abord as tu établi la relation (client-facture) dans ton Dataset?
- Si oui tu devrais pouvoir récupérer les factures "enfants" de ton client "parent" avec la fonction GetChild() (je ne suis pas très sûre de la syntaxe) dans une liste... Avec un Dataset fortement typé c'est encore plus simple.
Pour plus de détailles fais un tour sur developpez.com dans la section dotNet et fais une recherche sur les tutoriels en rapport avec ADO. Net et C#.
Simplement si tu as MSDN fais une recherche.
laurent180
Messages postés72Date d'inscriptionvendredi 4 avril 2003StatutMembreDernière intervention 2 novembre 2008 8 févr. 2008 à 09:57
Bonjour a tous,
Merci de votre aide.
Je travail bien avec un dataset et je fait bien une datarelation entre les datatables.
Mais j'aimerai lorsque j'affiche un client que j'ai en dessous toutes la factures qui s'y rapporte dans un datagriedview.
Mais le datagridview il m'affiche toute la table "facture" et pas juste les factures du clients selectionné.
bidou_01
Messages postés134Date d'inscriptiondimanche 1 octobre 2006StatutMembreDernière intervention19 mai 20081 8 févr. 2008 à 10:59
Hello,
L'erreur classique c'est de crée les relations, mais d'oublier de les ajouter au DataSet :
monDS.Relations.Add(madataRelation);
Sinon, comme ça je vois pas d'ou peut venir l'erreur, à priori les DataRelation devraient suffire...
Sinon tu as la solution de "facilité" en utilisant les BindingSource.
Ou alors binder ton deuxième DataGridView à une DataView ou tu changerais le RowFilter "à la mano" à chaque changement de client dans ton premier gridView :) (mais bof)
new
DataRelation(
"FK_OrderDetail_Reference_Order", l_colMasterOrder, l_colDetailOrder);
this.m_ds.Relations.Add(l_relOrderDetail);
//ajout de la relation au dataset
//binding du dataGrid affichant les clients au datasetdataGridView_customers.DataSource this.m_ds;dataGridView_customers.DataMember
"Customers" ;
//binding du dataGrid affichant les achats au datasetdataGridView_orders.DataSource this.m_ds;dataGridView_orders.DataMember
"Customers.FK_Order_Reference_Customer" ;
//binding du dataGrid affichant le d‚tail des achats au datasetdataGridView_detailsOrders.DataSource this.m_ds;dataGridView_detailsOrders.DataMember
laurent180
Messages postés72Date d'inscriptionvendredi 4 avril 2003StatutMembreDernière intervention 2 novembre 2008 11 févr. 2008 à 13:41
Bonjour,
J'ai essayé DataGridView1.DataMember = "client.dr1"
Il ne me met plus d'erreur mais il m'affiche tjs la meme facture dans DataGridView1
donc je vais faire une petite recherche mais tes conseils m'on deja beaucoup aidé.
je vais essayé aussi avec GetChildRows.
je ferai sa ce soir.
laurent180
Messages postés72Date d'inscriptionvendredi 4 avril 2003StatutMembreDernière intervention 2 novembre 2008 12 févr. 2008 à 08:10
Bonjour,
J'ai encore essayé avec DataGridView1.DataMember = "client.dr1"
a chaque fois il m'affiche les factures avec "id_client = 3". Pourquoi? je sais pas.
si j'ai plusieur facture dont le id client est = a 3 il me les affiche et si y en a pas il ne m'affiche rien.
c bizarre je comprend pas pq?
en fait j'ai un listbox dans le quel j'ai les nom des client et quand je clique dessus il m'affiche toutes les info du clients selectionné dans des textbox (sa sa fonctionne)
puis normalement il devrai m'affiché dans le datagriedview1 la liste des facture s'y rapportant.
voila le code.
dans le form_load.
je charge les 2 dataset puis je me deconnecte et je fais:
'definir 2 colonne pour mettre les 2 table en relation
Dim dccleprimaire As DataColumn
Dim dccleexterne As DataColumn
'Dim dr1 As DataRelation
dccleprimaire = ObjetDataSet.Tables("client").Columns("id_nom")
dccleexterne = ObjetDataSet.Tables("facture").Columns("id_nom")
Dim TablePersonnes As DataTable = ObjetDataSet.Tables("client")
Dim TableFonctions As DataTable = ObjetDataSet.Tables("facture")
'etablir la relation
dr1 = New DataRelation("dr1", dccleprimaire, dccleexterne, False)
'associer la relation au dataset
ObjetDataSet.Relations.Add(dr1)
et lorsque je selectionne un client ds listbox:
Private Sub ListBox1_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles ListBox1.Click
index = ListBox1.SelectedIndex
DataGridView1.ClearSelection()