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

Développement SQL Server Discussion :

OPENXML avec plusieurs balises identiques


Sujet :

Développement SQL Server

  1. #1
    Membre éprouvé
    Avatar de HULK
    Inscrit en
    Juillet 2003
    Messages
    1 274
    Détails du profil
    Informations personnelles :
    Âge : 44

    Informations forums :
    Inscription : Juillet 2003
    Messages : 1 274
    Points : 1 280
    Points
    1 280
    Par défaut OPENXML avec plusieurs balises identiques
    Bonjour,

    je charge un fichier XML dans SQL SERVER grace à OPENXML.

    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
     
    DECLARE @idoc int
    SELECT @XMLdoc = '<?xml version="1.0"?> 
    <TracePollData>
     <traces>
       <time>2011-09-14T19:46:07.043Z</time> 
    	 <property>
    	  <key>ATY</key> 
    	  <value>LI</value> 
    	  </property>
    	 <property>
    	  <key>TOTO</key> 
    	  <value>TATA</value> 
    	 </property>
     </traces>
    </TracePollData> '
     
    EXEC sp_xml_preparedocument @idoc OUTPUT, @XMLDoc
     
    SELECT * FROM OPENXML (@idoc, 'TracePollData/traces')
    WITH (time varchar(50) 'time', [key] varchar(15) 'property/key', value Varchar(15) 'property/value')
     
    EXEC sp_xml_removedocument @idoc
    Pour une balise "time", je peux avoir plusieurs balises property, dans le code ci dessus, j'en ai 2, mais le code me renvoi qu'une ligne :

    2011-09-14T19:46:07.043Z ATY LI

    J'aimerai qu'il me retourne 2 lignes :


    2011-09-14T19:46:07.043Z ATY LI
    2011-09-14T19:46:07.043Z TOTO TATA


    Comment faire ?

    Merci
    j'suis vert !

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 768
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 768
    Points : 52 719
    Points
    52 719
    Billets dans le blog
    5
    Par défaut
    Un simple problème Xquery. Avec votre syntaxe vous ne vous intéressez qu'à l'élément de position 1.
    Pour utiliser les autres, précisez le singleton.

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    Membre éprouvé
    Avatar de HULK
    Inscrit en
    Juillet 2003
    Messages
    1 274
    Détails du profil
    Informations personnelles :
    Âge : 44

    Informations forums :
    Inscription : Juillet 2003
    Messages : 1 274
    Points : 1 280
    Points
    1 280
    Par défaut
    J'ai rien compris mais ca m'a aidé ! J'ai modifié ma syntaxe et ca fonctionne, je ne sais pas si c'est ce que vous vouliez dire

    merci M'sieur

    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
    25
    26
    27
     
    DECLARE @XMLdoc XML
    DECLARE @idoc int
    SELECT @XMLdoc = '<?xml version="1.0"?> 
    <TracePollData>
     <traces>
       <time>2011-09-14T19:46:07.043Z</time> 
    	 <property>
    	  <key>ATY</key> 
    	  <value>LI</value> 
    	  </property>
    	 <property>
    	  <key>TOTO</key> 
    	  <value>TATA</value> 
    	 </property>
     </traces>
    </TracePollData> '
     
    EXEC sp_xml_preparedocument @idoc OUTPUT, @XMLDoc
     
    SELECT * FROM OPENXML (@idoc, 'TracePollData/traces/property')
    WITH (
    time varchar(50) '../time', 
    [key] varchar(15) 'key', 
    value Varchar(15) 'value')
     
    EXEC sp_xml_removedocument @idoc
    j'suis vert !

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

Discussions similaires

  1. Metadata XML - plusieurs balises avec le même nom
    Par Viceloque dans le forum Développement de jobs
    Réponses: 5
    Dernier message: 05/03/2020, 13h23
  2. Réponses: 1
    Dernier message: 07/12/2011, 20h18
  3. [XL-2007] Extraire des données d'un fichier Xml avec des balises identiques
    Par Danieldu54 dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 08/03/2011, 20h45
  4. Réponses: 4
    Dernier message: 10/10/2007, 11h11
  5. Réponses: 4
    Dernier message: 29/01/2007, 11h54

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