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

Windows Forms Discussion :

[VB-VS2005]Appliquer une requete sur un datset deja rempli


Sujet :

Windows Forms

  1. #1
    Membre régulier Avatar de Pasiphae
    Inscrit en
    Octobre 2003
    Messages
    110
    Détails du profil
    Informations forums :
    Inscription : Octobre 2003
    Messages : 110
    Points : 104
    Points
    104
    Par défaut [VB-VS2005]Appliquer une requete sur un datset deja rempli
    Bonjour a tous !

    J'aimerais appliquer une requete utilisant des relations entre différentes tables à un dataset fortement typé qui contient déjà des données chargées depuis un fichier xml.
    J ai essayé d utiliser un DataTable.Select mais les données ne peuvent être que de la table selectionnée, or vu que je cherche a appliquer une requete sur deux tables (un simple inner join), cela ne fonctionne pas.

    Tous les exemples que j ai pu trouver implique d utiliser un objet commande et un object connection, or mes données provenant d un xml je vois mal comment utiliser un objet connection. ^^ Bref, je suis bloquée.

    Si vous avez une idée de piste ou de solution, cela serait tres gentil de me l indiquer. Par avance merci beaucoup.

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

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 627
    Points : 7 879
    Points
    7 879
    Par défaut
    En effet gros soucis pour les jointures qui ne se réalisent pas aisément, donc dans ton cas il y a la piste d'agir par du xml > je suppose que xpath doit permettre ce genre de manip

    System.Xml.XPath Namespace
    Pour le bien de ceux qui vous lisent, ayez à coeur le respect du forum et de ses règles

  3. #3
    Membre régulier Avatar de Pasiphae
    Inscrit en
    Octobre 2003
    Messages
    110
    Détails du profil
    Informations forums :
    Inscription : Octobre 2003
    Messages : 110
    Points : 104
    Points
    104
    Par défaut
    Merci pour l'information.
    J'ai cherché dans ce sens. Effectivement en theorie cela semble realisable, en pratique, cela ne fonctionne pas comme je l aurais souhaité (j ai certainement fait une erreur quelque part)...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
            Dim document As XPathDocument = New XPathDocument("UserGrids.xml")
            Dim navigator As XPathNavigator = document.CreateNavigator()
            Dim node As XPathNodeIterator = navigator.Select("/root/Formulaire[normalize-space(@Nom)='Groupe']")
            MsgBox(node.Current.Name)
    La boite de dialogue renvoie un joli champ vide. Je craque... Je sens que je vais laisser tomber le xml si ça continue à être la poisse a manipuler.

  4. #4
    Membre régulier Avatar de Pasiphae
    Inscrit en
    Octobre 2003
    Messages
    110
    Détails du profil
    Informations forums :
    Inscription : Octobre 2003
    Messages : 110
    Points : 104
    Points
    104
    Par défaut
    Bon j'ai trouvé une autre voie (encore une).
    Pour ceux que ça intéresserait voici ma methode (il y a surement mieux) :

    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
     
            Dim _data As UserGrids = New UserGrids 'Dataset fortement typé
            Dim xmlDoc As XmlDataDocument = New XmlDataDocument(_data)
     
            'Charge le schema de données
            xmlDoc.DataSet.ReadXmlSchema("UserGrids.xsd")
     
            'Charge les données xml
            xmlDoc.Load("UserGrids.xml")
     
               Dim tb As DataTable = _data.Formulaire 'xmlDoc.DataSet.Tables.Item("Formulaire")
            Dim foundRows() As DataRow
            foundRows = tb.Select("Nom ='Groupe'")
     
     
            Dim gridRows As DataRow
            For Each rw As DataRow In foundRows
                gridRows = rw.GetChildRows("Formulaire_Grille")
            Next
    J ai enlevé les details mais en gros je boucle de childrow en chidrow avec le nom de la relation entre les tables. C'est pas tres "joli" mais ca fonctionne. voila.

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 15/06/2007, 12h06
  2. Execution d'une requete sur un resultat précédent
    Par Systemic7 dans le forum Langage SQL
    Réponses: 6
    Dernier message: 02/08/2005, 14h43
  3. Réponses: 2
    Dernier message: 07/07/2005, 08h31
  4. Réponses: 3
    Dernier message: 06/07/2004, 10h21
  5. [icone]Comment appliquer une icone sur le.exe
    Par JavaLeDirePartout dans le forum JBuilder
    Réponses: 7
    Dernier message: 24/07/2003, 17h28

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