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

SQL Oracle Discussion :

XML/Oracle requete avec l'utilisation de xmlagg


Sujet :

SQL Oracle

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    104
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 104
    Points : 40
    Points
    40
    Par défaut XML/Oracle requete avec l'utilisation de xmlagg
    Bonjour,
    est il possible d'avoir plus que 2 niveaux d'imbrication avec la fonction xmlagg
    de style :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    select 
      xmlelement(
        emp,
        xmlagg(
          xmlelement(
            dept,
            xmlattributes(deptno),
            xmlagg(sys_xmlgen(empno)),
                xmlagg(xmlelement( noeud, xmlelement(champ1))))) 
    from emp 
    group by deptno;
    j'ai toujours un message ORA-00935 : imbrication de fonction de groupe trop profonde
    Merci d'avance

  2. #2
    Membre éclairé Avatar de plabrevo
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    547
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 547
    Points : 670
    Points
    670
    Par défaut
    Il n'y a que deux niveaux possibles, en theorie et en pratique sinon, a quel groupe de rupture serait associee la troisieme fonction XMLAgg?

    La solution consiste plutot a utiliser des requetes imbriquees:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT xmlelement(DeptList,XMLAgg(xmlelement(dept,xmlattributes(deptno),jobelement))))element
    FROM  (SELECT deptno,XMLAgg(xmlelement(job,xmlattributes(job),emplist)) jobelement
           FROM  (SELECT deptno,job, XMLAgg(xmlelement(emp,xmlattributes(empno),xmlelement(sal, sal))) emplist
                  FROM   emp
                  GROUP BY
                         deptno,job)
           GROUP BY deptno)
    /

    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
     
    <DEPTLIST>
      <DEPT DEPTNO="10">
        <JOB JOB="Clerk    ">
          <EMP EMPNO="7934"><SAL>920</SAL></EMP>
        </JOB>
        <JOB JOB="Manager  ">
          <EMP EMPNO="7782"><SAL>2572.5</SAL></EMP>
        </JOB>
        <JOB JOB="President">
          <EMP EMPNO="7839"><SAL>5500</SAL></EMP>
        </JOB>
      </DEPT>
      <DEPT DEPTNO="20">
        <JOB JOB="Analyst  ">
          <EMP EMPNO="7658"><SAL>3450</SAL></EMP>
        </JOB>
        <JOB JOB="Manager  ">
          <EMP EMPNO="7566"><SAL>3123.75</SAL></EMP>
        </JOB>
      </DEPT>
      <DEPT DEPTNO="30">
        <JOB JOB="Salesman ">
          <EMP EMPNO="7499"><SAL>1600</SAL></EMP>
          <EMP EMPNO="7654"><SAL>1312.5</SAL></EMP>
        </JOB>
      </DEPT>
    </DEPTLIST>

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

Discussions similaires

  1. [Oracle] Requête avec GROUP BY
    Par bud_gw dans le forum Langage SQL
    Réponses: 3
    Dernier message: 03/07/2006, 10h26
  2. Réponses: 13
    Dernier message: 25/04/2006, 09h43
  3. [REQUETE ORACLE] Vols avec ou sans escales
    Par e-lifestyle dans le forum Oracle
    Réponses: 7
    Dernier message: 06/01/2006, 22h46
  4. cmt se connecté a oracle pour faire une requete avec python
    Par dipajero dans le forum Bibliothèques tierces
    Réponses: 6
    Dernier message: 28/12/2005, 20h22
  5. oracle 8.1.7, CLOB et requete avec like
    Par fsapet dans le forum Oracle
    Réponses: 5
    Dernier message: 15/02/2005, 11h45

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