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

XSL/XSLT/XPATH XML Discussion :

Extraction d information d' un fichier datasource de JBoss


Sujet :

XSL/XSLT/XPATH XML

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Avril 2009
    Messages
    19
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Avril 2009
    Messages : 19
    Par défaut Extraction d information d' un fichier datasource de JBoss
    Bonjour a tous

    J aurai une question pour vous: j ai un fichier DS de JBoss. Je souhaiterai le parser pour m assurer de certaines validations.

    Voici le format:

    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
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
     
    <?xml version="1.0" encoding="UTF-8"?>
     
    <datasources>
     <xa-datasource>
        <jndi-name>DS1/ApplicationDS</jndi-name>
        <track-connection-by-tx/>
        <isSameRM-override-value>false</isSameRM-override-value>
        <xa-datasource-class>oracle.jdbc.xa.client.OracleXADataSource</xa-datasource-class>
        <xa-datasource-property name="URL">Url1</xa-datasource-property>
        <xa-datasource-property name="User">User1</xa-datasource-property>
        <xa-datasource-property name="Password">Pass1</xa-datasource-property>
        <transaction-isolation>TRANSACTION_READ_COMMITTED</transaction-isolation>    
        <!--pooling parameters-->
        <min-pool-size>0</min-pool-size>
        <max-pool-size>10</max-pool-size>
        <blocking-timeout-millis>5007</blocking-timeout-millis>
        <idle-timeout-minutes>1</idle-timeout-minutes><background-validation-millis>40000</background-validation-millis> 
        <prepared-statement-cache-size>100</prepared-statement-cache-size>   
     
        <!--valid-connection-checker-class-name>org.jboss.resource.adapter.jdbc.vendor.OracleValidConnectionChecker</valid-connection-checker-class-name-->
        <!-- Checks the Oracle error codes and messages for fatal errors -->
        <exception-sorter-class-name>org.jboss.resource.adapter.jdbc.vendor.OracleExceptionSorter</exception-sorter-class-name>
        <!-- Oracles XA datasource cannot reuse a connection outside a transaction once enlisted in a global transaction and vice-versa -->
        <no-tx-separate-pools/>
     
          <!-- corresponding type-mapping in the standardjbosscmp-jdbc.xml -->
          <metadata>
             <type-mapping>Oracle9i</type-mapping>
          </metadata>
      </xa-datasource>
     
     <xa-datasource>
        <jndi-name>DS2/ApplicationDS</jndi-name>
        <track-connection-by-tx/>
        <isSameRM-override-value>false</isSameRM-override-value>
        <xa-datasource-class>oracle.jdbc.xa.client.OracleXADataSource</xa-datasource-class>
        <xa-datasource-property name="URL">Url2</xa-datasource-property>
        <xa-datasource-property name="User">User2</xa-datasource-property>
        <xa-datasource-property name="Password">Pass2</xa-datasource-property>
        <transaction-isolation>TRANSACTION_READ_COMMITTED</transaction-isolation>    
        <!--pooling parameters-->
        <min-pool-size>0</min-pool-size>
        <max-pool-size>10</max-pool-size>
        <blocking-timeout-millis>5007</blocking-timeout-millis>
        <idle-timeout-minutes>1</idle-timeout-minutes><background-validation-millis>40000</background-validation-millis> 
        <prepared-statement-cache-size>100</prepared-statement-cache-size>   
     
        <!--valid-connection-checker-class-name>org.jboss.resource.adapter.jdbc.vendor.OracleValidConnectionChecker</valid-connection-checker-class-name-->
        <!-- Checks the Oracle error codes and messages for fatal errors -->
        <exception-sorter-class-name>org.jboss.resource.adapter.jdbc.vendor.OracleExceptionSorter</exception-sorter-class-name>
        <!-- Oracles XA datasource cannot reuse a connection outside a transaction once enlisted in a global transaction and vice-versa -->
        <no-tx-separate-pools/>
     
          <!-- corresponding type-mapping in the standardjbosscmp-jdbc.xml -->
          <metadata>
             <type-mapping>Oracle9i</type-mapping>
          </metadata>
      </xa-datasource>
    </datasources>
    Et je souhaiterai sortir
    "
    JNDI-Name=DS1/ApplicationDS, User=User1, Pass=Pass1
    JNDI-Name=DS2/ApplicationDS, User=User2, Pass=Pass2"


    etc...
    Seulement je recupere bien l integralite des elements separes:
    //xa-datasource/jndi-name
    //xa-datasource-property[@name="User"]
    //xa-datasource-property[@name="Password"]
    Mais quand je concatene (teste sous Notepad++) cela plante... un seul record:
    concat("JNDI-Name = ",//xa-datasource/jndi-name," - User= ",//xa-datasource-property[@name="User"]," - Password = ",//xa-datasource-property[@name="Password"])

    Quelqu un pourrait m aider ?

    EDIT-->
    J ai lu sur la doc du site:
    "
    4-A. Concat

    concat( string , string , string *) : retourne string

    Elle retourne le résultat de la concaténation des arguments. Attention, lui passer un nodeset de plusieurs noeuds en paramètre ne permettra pas la concaténation de leur valeur textuelle. Chaque nodeset est considéré comme un seul argument et à ce titre seul le premier noeud est traité.

    Exemple :

    concat("AB","CDE","EF") retourne ABCDEF"

    Y a t il un workaround ?

  2. #2
    Membre Expert Avatar de tsuji
    Inscrit en
    Octobre 2011
    Messages
    1 558
    Détails du profil
    Informations forums :
    Inscription : Octobre 2011
    Messages : 1 558
    Par défaut
    Si je comprends bien, pour obtenir la première ligne de donnée
    JNDI-Name=DS1/ApplicationDS, User=User1, Pass=Pass1
    c'est fait comme ça?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    concat("JNDI-Name = ",
        /datasources/xa-datasource[1]/jndi-name,
        " - User= ",
        /datasources/xa-datasource[1]/xa-datasource-property[@name="User"],
        " - Password = ",
        /datasources/xa-datasource[1]/xa-datasource-property[@name="Password"]
    )
    Laboreux, mais je mets tous les étapes pour être plus claire.

    Pareil pour la seconde ligne de donnée:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    concat("JNDI-Name = ",
        /datasources/xa-datasource[2]/jndi-name,
        " - User= ",
        /datasources/xa-datasource[2]/xa-datasource-property[@name="User"],
        " - Password = ",
        /datasources/xa-datasource[2]/xa-datasource-property[@name="Password"]
    )
    D'ailleurs, je ne vois pas claire ce qui veut démontrer l'exemple: c'est de jamais vu, il doit retourner "ABCDEEF".

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Avril 2009
    Messages
    19
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Avril 2009
    Messages : 19
    Par défaut
    @tsuji:

    merci pour ta reponse.
    Je voulais savoir s il etait possible en XPATH de sortir l integralite des records avec une requete

    (en fait s epargner le

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    concat("JNDI-Name = ",
        /datasources/xa-datasource[i]/jndi-name,
        " - User= ",
        /datasources/xa-datasource[i]/xa-datasource-property[@name="User"],
        " - Password = ",
        /datasources/xa-datasource[i]/xa-datasource-property[@name="Password"]
    )
    avec i de 1 a count(//datasources)

    ^^

    Le but est d etre generique

    Et pour l exemple my fault j ai recupere celui du site.

  4. #4
    Membre Expert Avatar de tsuji
    Inscrit en
    Octobre 2011
    Messages
    1 558
    Détails du profil
    Informations forums :
    Inscription : Octobre 2011
    Messages : 1 558
    Par défaut
    Le but est d etre generique
    Soit... être concret est peut-être mondain. L'issue est [1] contain() s'est assez intégrée dans le langage de xpath tant que si elle apparait, elle n'a pas l'effet de mettre le xpath moins générique; [2] tant qu'il y ait de noms concrets de noeudes à travailler, le xpath ne serait mal à rester tout à fait générique, n'est-ce pas? [3] il se peut de faire une fonction dans xslt (extension ou v2.0) pour ce but et qui a pour effet cacher la spécificité de travail pour un document xml du type configuratif spécifique stable dans un environment specifique comme JBoss, mais ça n'est que reporter la spécificité d'un niveau à l'autre.

    En somme, je ne peux pas souscrire à tel but et je ne sais pas comme faire pour être totalement générique dans ce cas.

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Avril 2009
    Messages
    19
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Avril 2009
    Messages : 19
    Par défaut
    Desole je n ai pas pu consulter depuis qq temps

    Je n ai pas bien compris ton message. Peux tu me le re-expliquer ?
    Merci

Discussions similaires

  1. extraction d'informations d'un fichier
    Par jane40 dans le forum R
    Réponses: 3
    Dernier message: 12/05/2011, 12h52
  2. extraction d'information d'un fichier text
    Par g.abdou dans le forum Unix
    Réponses: 2
    Dernier message: 14/08/2010, 16h15
  3. Réponses: 4
    Dernier message: 05/12/2009, 23h50

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