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

Accès aux données Discussion :

sql server 2005 et le type XML et XQUERY


Sujet :

Accès aux données

  1. #1
    Membre expérimenté
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 103
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 103
    Points : 1 561
    Points
    1 561
    Par défaut sql server 2005 et le type XML et XQUERY
    Bonjour,

    Voila, j'ai une table ressemblant à cela

    type varchar(100)
    name varchar(100)
    value xml

    jusque là tout va bien...
    insérer des données directement dedans ne pose aucun problème.

    Cependant je souhaiterais plutot que d'insérer les données moi meme, via un SqlAdapter et des commandes insert mappées sur une table ADO.NET,

    transmettre une liste d'entrées à ajouter à la table via un champ XML.

    Ainsi, cette procédure sp_modules_register prend comme paramètre @modules xml.

    Mon problème c'est que je recois un document

    <modules>
    <module name="identifiant">
    <properties name="titre">
    ...
    </properties>
    ...
    </module>
    <module name="identifiant">
    ...
    </module>
    ...
    </modules>

    pour pouvoir faire mon insertion je dois pouvoir faire une requete sur ce bloc XML et extraire deux colonnes... d'un coté le contenu de l'attribut name du noeud "module" et de l'autre coté, tout le noeud "module" en xml.

    problème en Xquery je sais faire la seconde chose... extraire les différents modules, mais j'ignore comment récupérer le nom défini dans la valeur de l'attribut name de <module name="...">
    et franchement les quelques docs très sommaires sur xquery sontpas forcément évidentes à comprendre dans la mesures où aucune d'entre elle ne va droit au but.

  2. #2
    Rédacteur
    Avatar de SaumonAgile
    Homme Profil pro
    Team leader
    Inscrit en
    Avril 2007
    Messages
    4 028
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Team leader
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2007
    Messages : 4 028
    Points : 6 334
    Points
    6 334
    Par défaut
    En XQuery, je ne sais pas, mais en XPath pour récupérer la valeur d'un attribut, on utilise cette syntaxe : "properties/@name"
    Besoin d'un MessageBox amélioré ? InformationBox pour .NET 1.1, 2.0, 3.0, 3.5, 4.0 sous license Apache 2.0.

    Bonnes pratiques pour les accès aux données
    Débogage efficace en .NET
    LINQ to Objects : l'envers du décor

    Mon profil LinkedIn - MCT - MCPD WinForms - MCTS Applications Distribuées - MCTS WCF - MCTS WCF 4.0 - MCTS SQL Server 2008, Database Development - Mon blog - Twitter

  3. #3
    Membre expérimenté
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 103
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 103
    Points : 1 561
    Points
    1 561
    Par défaut
    oui je pensais que ct XPath mais j'ai quand meme un problème...
    quand j'effectue cette requete sur une simple entrée XML ne contenant qu'un descripteur et non une liste...

    select [value].query('ModuleDescriptor/@name') from xconfig

    => Msg*2396, Niveau*16, État*1, Ligne*3
    XQuery [xconfig.value.query()]: L'attribut ne peut pas apparaître en dehors d'un élément

    bref c'est pas encore ca

    et si j'essaie query('ModuleDescriptor[@name]') il me retourne le xml complet du noeud, vu que ba... [] test si le noeud ModuleDescriptor possède un attribut @name.

  4. #4
    Rédacteur
    Avatar de SaumonAgile
    Homme Profil pro
    Team leader
    Inscrit en
    Avril 2007
    Messages
    4 028
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Team leader
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2007
    Messages : 4 028
    Points : 6 334
    Points
    6 334
    Par défaut
    Et avec ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    [value].value('(ModuleDescriptor/@name)[1]', 'int' )
    Besoin d'un MessageBox amélioré ? InformationBox pour .NET 1.1, 2.0, 3.0, 3.5, 4.0 sous license Apache 2.0.

    Bonnes pratiques pour les accès aux données
    Débogage efficace en .NET
    LINQ to Objects : l'envers du décor

    Mon profil LinkedIn - MCT - MCPD WinForms - MCTS Applications Distribuées - MCTS WCF - MCTS WCF 4.0 - MCTS SQL Server 2008, Database Development - Mon blog - Twitter

  5. #5
    Rédacteur
    Avatar de SaumonAgile
    Homme Profil pro
    Team leader
    Inscrit en
    Avril 2007
    Messages
    4 028
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Team leader
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2007
    Messages : 4 028
    Points : 6 334
    Points
    6 334
    Par défaut
    Alors ? Tu en es où ?
    Besoin d'un MessageBox amélioré ? InformationBox pour .NET 1.1, 2.0, 3.0, 3.5, 4.0 sous license Apache 2.0.

    Bonnes pratiques pour les accès aux données
    Débogage efficace en .NET
    LINQ to Objects : l'envers du décor

    Mon profil LinkedIn - MCT - MCPD WinForms - MCTS Applications Distribuées - MCTS WCF - MCTS WCF 4.0 - MCTS SQL Server 2008, Database Development - Mon blog - Twitter

  6. #6
    Membre expérimenté
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 103
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 103
    Points : 1 561
    Points
    1 561
    Par défaut
    c'est presque bon... je tiens le bon bout, grâce à ton aide précieuse.

    j'aurais cependant une dernière question sur le sujet avant de le clore.

    si je récupère un document xml genre

    <modules>
    <module name="a">...</module>
    <module name="b">...</module>
    <module name="c">...</module>
    <module name="d">...</module>
    </modules>

    dans un paramètre d'entrée d'une proc comme @mods

    si je fait

    select @mods.query('/modules/module')
    il va me retourner sagement dans UN SEUL BLOC XML (un seul enregistrement)
    tous les noeuds module...

    existe t'il un moyen plus rapide de faire en sorte qu'il me retourne un noeud par enregistrement, autrement que de passer par une boucle while avec un compteur permettant de récupèrer le noeud manuellement :

    comme ce code vraiment crade ...
    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
     
    declare @c int
    declare @m xml
    set @c = 0
     
    select @m = @mods.query('(/modules/module)['+@c+']')
    while isnull(@m, '') != ''
    begin
      /*
        traitements dépendant de @m
        ...
       */
      set @c = @c + 1
      select @m = @mods.query('(/modules/module)['+@c+']')
    end

  7. #7
    Rédacteur
    Avatar de SaumonAgile
    Homme Profil pro
    Team leader
    Inscrit en
    Avril 2007
    Messages
    4 028
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Team leader
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2007
    Messages : 4 028
    Points : 6 334
    Points
    6 334
    Par défaut
    J'ai trouvé ça : http://aspnet.4guysfromrolla.com/articles/071603-1.aspx
    Je ne suis pas expert mais la construction FLWR (détaillée en bas de l'article) semblerait correspondre à ton besoin.
    Besoin d'un MessageBox amélioré ? InformationBox pour .NET 1.1, 2.0, 3.0, 3.5, 4.0 sous license Apache 2.0.

    Bonnes pratiques pour les accès aux données
    Débogage efficace en .NET
    LINQ to Objects : l'envers du décor

    Mon profil LinkedIn - MCT - MCPD WinForms - MCTS Applications Distribuées - MCTS WCF - MCTS WCF 4.0 - MCTS SQL Server 2008, Database Development - Mon blog - Twitter

  8. #8
    Membre expérimenté
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 103
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 103
    Points : 1 561
    Points
    1 561
    Par défaut
    bon ba pour l'instant j'ai pas encore trouvé...

    les expressions FLWR ne règle pas le problème... en effet, ce qui ressort est tjs sous forme d'une seule expression (un enregistrement).

    voici le code SQL utilisé en attendant de trouver mieux:
    retourne une table de (nom, document xml)

    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
     
    CREATE PROCEDURE sp_modules
      @modules xml
    AS
    BEGIN
    declare @t table (name varchar(100), field xml)
    declare @c int
    declare @n int
    declare @m xml
     
    -- récupère le nombre de noeud module dans le noeud racine
    select @n = @modules .value('count(//module)', 'int')
    set @c = 1
     
    while @c <= @n
    begin
      -- extrait dans @m l'élément courant correspondant à l'index recherché
      select @m = @modules .query('//module[sql:variable("@c")]')
      set @c = @c + 1
      insert into @t select @m.value('(/module/@name)[1]', 'varchar(100)'), @m
    end
     
    select * from @t
    end
    avec @modules de la forme

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    <modules>
    <module name="a">...</module>
    <module name="b">...</module>
    <module name="c">...</module>
    <module name="d">...</module>
    </modules>

  9. #9
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    204
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 204
    Points : 64
    Points
    64
    Par défaut
    Moi j'ai un problème lié à ce sujet j'ai une transformation d'un fichier xml à un arbre le problème c'est que ça marche avec Firefox mais pas avec IE et moi je souheterais que ça marche avec IE quelqu'un sait comment on fait

    Merci

Discussions similaires

  1. [SQL Server 2005] Importer des données XML
    Par ni0urk dans le forum MS SQL Server
    Réponses: 8
    Dernier message: 22/05/2008, 09h06
  2. type boolean en SQL SERVER 2005
    Par solawe dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 17/07/2007, 13h03
  3. stockage word en xml dans une base sql server 2005
    Par morados dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 10/10/2006, 10h47
  4. ORDER BY d'un type ntext sql server 2005
    Par charabia dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 16/02/2006, 07h37

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