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

XQUERY/SGBD XML Discussion :

[XQuery] Compteur ?


Sujet :

XQUERY/SGBD XML

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 3
    Points : 2
    Points
    2
    Par défaut [XQuery] Compteur ?
    Bonjour à tous,

    connaissez-vous une méthode pour utiliser un compteur en XQuery ? Je m'explique.

    J'ai un xml d'entrée A que je mappe avec un xml de sortie B. Disons que A contient un noeud répétitif de 5 éléments dont 3 répondent à mes critères. Je mappe ces 3 noeuds dans un noeud répétitif de B, mais j'aimerais ajouter en plus un ID qui indique 1, 2 puis 3.

    Mon idée de base était de faire :
    let $count := 0
    puis après le for
    $count := $count + 1
    mais ca n'a pas l'air de passer...

    Je n'ai pas trouvé de fonction qui permette de dire dans quelle itération du noeud de sortie on se trouve, mais je pense qu'il doit bien exister une méthode.

    D'avance, merci beaucoup pour votre aide.

  2. #2
    Membre éprouvé
    Profil pro
    Responsable Dev
    Inscrit en
    Décembre 2003
    Messages
    788
    Détails du profil
    Informations personnelles :
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Responsable Dev

    Informations forums :
    Inscription : Décembre 2003
    Messages : 788
    Points : 1 063
    Points
    1 063
    Par défaut
    peut être une idée utiliser la fonction position()

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 3
    Points : 2
    Points
    2
    Par défaut
    Merci, mais sauf si je comprend mal, position() ne s'utilise que dans les crochets genre noeud[position()>X].

  4. #4
    Membre éprouvé
    Profil pro
    Responsable Dev
    Inscrit en
    Décembre 2003
    Messages
    788
    Détails du profil
    Informations personnelles :
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Responsable Dev

    Informations forums :
    Inscription : Décembre 2003
    Messages : 788
    Points : 1 063
    Points
    1 063
    Par défaut
    en faite tu peux l'utiliser partout il s'agit d'une fonction XPATH
    un exemple pour répondre à ton problème
    ton fichier xml
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    <root>
    <a>
    	<b critere="ok">et 1 de bon</b>
    	<b critere="ok">et 1 de bon</b>
    	<b critere="pas ok">pas bon</b>
    	<b critere="ok">et 1 de bon</b>
    </a>
    </root>
    ton fichier xsl
    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
     
    <?xml version="1.0" encoding="ISO-8859-1"?>
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
     
    <xsl:output 
      encoding="ISO-8859-15"
      method="xml"
      indent="yes" />
     
    <xsl:template match="/">
      <root>
          <xsl:apply-templates select="//b[@critere='ok']" />
      </root>
    </xsl:template>
     
    <xsl:template match="b">
      <trouver>
    	<xsl:attribute name="id"><xsl:value-of select="position()"/></xsl:attribute>
        	<xsl:value-of select="." />
      </trouver>
    </xsl:template>
     
    </xsl:stylesheet>
    le fichier xml obtenu
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    <root>
    <trouver id="1">et 1 de bon</trouver>
    <trouver id="2">et 1 de bon</trouver>
    <trouver id="3">et 1 de bon</trouver>
    </root>

  5. #5
    Rédacteur

    Avatar de Erwy
    Homme Profil pro
    Développeur Web
    Inscrit en
    Novembre 2003
    Messages
    4 967
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2003
    Messages : 4 967
    Points : 10 927
    Points
    10 927
    Par défaut
    Xquery ce n'est pas XSLT , ton exemple ne va pas bcp l'aider

    regarde ici
    http://www.w3schools.com/xquery/xquery_select.asp
    je crois que c'est ce que tu cherche

    The at keyword can be used to count the iteration:

    for $x at $i in doc("books.xml")/bookstore/book/title
    return <book>{$i}. {data($x)}</book>

    Result:

    <book>1. Everyday Italian</book>
    <book>2. Harry Potter</book>
    <book>3. XQuery Kick Start</book>
    <book>4. Learning XML</book>

  6. #6
    Membre à l'essai
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Décembre 2008
    Messages : 12
    Points : 10
    Points
    10
    Par défaut
    je me permet de déterrer le topic pour rajouter une question.

    rajouter le "at" dans une boucle for, marche en effet très bien du moment que l'on affiche tous les éléments.

    Moi je suis confronté à un problème. Je veux affichier certains fichiers d'une collection (dans une base de donnée eXist), mais impossible d'avoir un index qui indique la position du résultat.

    Donc en gros si j'ai une liste de xml comme ça
    a.xml
    b.xml
    c.xml

    et que j'ai une requête qui me sort par exemple b et c alors j'aurais comme résultat du compteur
    2
    3
    aulieux d'avoir
    1
    2

Discussions similaires

  1. [XQuery] Faire un compteur
    Par majed.rais dans le forum XQUERY/SGBD
    Réponses: 1
    Dernier message: 03/06/2007, 17h06
  2. [XSL FO] Compteur a partir de 2
    Par Hugo001 dans le forum XSL/XSLT/XPATH
    Réponses: 7
    Dernier message: 30/06/2004, 11h39
  3. [PB CONCEPTUEL] avec compteur/trigger
    Par kase74 dans le forum SQL
    Réponses: 6
    Dernier message: 25/03/2004, 11h02
  4. Remise à 0 d'un compteur automatique
    Par missllyss dans le forum SQL
    Réponses: 4
    Dernier message: 15/12/2003, 16h46
  5. Migration Access > SQL Server (suite) : Compteur
    Par LadyArwen dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 06/03/2003, 14h08

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