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 :

Parser un champ avec retour chariot en plusieurs lignes


Sujet :

SQL Oracle

  1. #1
    Membre du Club
    Inscrit en
    Mars 2006
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 113
    Points : 48
    Points
    48
    Par défaut Parser un champ avec retour chariot en plusieurs lignes
    Bonjour à tous,

    Voici ma requête et ce que j'obtiens avec:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    SELECT NOM, LISTE_REL FROM PERSONNES;
     
    NOM   |  LISTE_REL
    NOM1 | REL11
               REL12
               REL13
    NOM2 | REL21
               REL22
               REL23
    Pour chaque ligne, j'ai un CLOB qui contient plusieurs informations, séparées par un retour chariot.

    J'aimerais obtenir ce résultat:

    NOM   |  LISTE_REL
    NOM1 | REL11
    NOM1 | REL12
    NOM1 | REL13
    NOM2 | REL21
    NOM2 | REL22
    NOM2 | REL23
    J'ai essayé pas mal de trucs, mais rien ne marche comme il faut... A l'aide !

    Merci d'avance !

    Philippe

  2. #2
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 950
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 950
    Points : 5 849
    Points
    5 849
    Par défaut
    Regarde Transformer les éléments d'une liste en enregistrement
    Avec des retours chariots (correspondant à chr(10)) ça peut donner :
    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
    61
    62
    63
    64
    65
    66
    SQL> column liste_rel format a30
    SQL> drop table personnes
      2  /
     
    Table dropped.
     
    SQL> create table PERSONNES (nom varchar2(20), liste_rel clob)
      2  /
     
    Table created.
     
    SQL> insert into PERSONNES values ('NOM1', 'REL11
      2  REL12
      3  REL13')
      4  /
     
    1 row created.
     
    SQL> insert into PERSONNES values ('NOM2', 'REL21
      2  REL22
      3  REL23')
      4  /
     
    1 row created.
     
    SQL> select * from personnes
      2  /
     
    NOM                  LISTE_REL
    -------------------- ------------------------------
    NOM1                 REL11
                         REL12
                         REL13
     
    NOM2                 REL21
                         REL22
                         REL23
     
     
    SQL> SELECT t.nom, x.column_value AS liste_rel
      2    FROM personnes t
      3   CROSS JOIN TABLE(
      4               cast(multiset(
      5                       SELECT substr( chr(10)||liste_rel||chr(10),
      6                                     instr( chr(10)||liste_rel||chr(10), chr(10), 1, rownum )+1,
      7                                     instr( chr(10)||liste_rel||chr(10), chr(10), 1, rownum+1 )
      8                                     -instr( chr(10)||liste_rel||chr(10), chr(10), 1, rownum )-1
      9                                    )
     10                         FROM dual
     11                      connect BY level <= length(liste_rel)-length(REPLACE(liste_rel,chr(10),''))+1
     12                            ) AS sys.odcivarchar2list )
     13                         ) x
     14  /
     
    NOM                  LISTE_REL
    -------------------- ------------------------------
    NOM1                 REL11
    NOM1                 REL12
    NOM1                 REL13
    NOM2                 REL21
    NOM2                 REL22
    NOM2                 REL23
     
    6 rows selected.
     
    SQL>

  3. #3
    Membre du Club
    Inscrit en
    Mars 2006
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 113
    Points : 48
    Points
    48
    Par défaut
    Tout d'abord, merci beaucoup pour ta réponse.

    Quand j'exécute simplement ta requête, voici l'erreur que j'ai:

    ORA-00904: "LISTE_REL" : identificateur non valide
    00904. 00000 - "%s: invalid identifier"
    *Cause:
    *Action:
    Erreur à la ligne 11, colonne 86
    (C'est le LISTE_REL du REPLACE)

    Je ne comprends pas pourquoi j'ai ça, j'ai essayé en préfixant avec "t.", mais rien ne change. :-(

    J'ai testé le même code que celui présent dans la page du lien que tu as envoyé, en faisant exactement les mêmes instructions, et j'obtiens la même erreur, au même endroit. :-(

    Mes compétences en SQL sont assez limitées, alors c'est peut être une erreur très simple, mais...

    Merci d'avance !

    Philippe

  4. #4
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 950
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 950
    Points : 5 849
    Points
    5 849
    Par défaut
    Quelle est la version d'oracle ? pour le savoir :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select * from v$version

  5. #5
    Membre du Club
    Inscrit en
    Mars 2006
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 113
    Points : 48
    Points
    48
    Par défaut
    Sur mon PC perso:

    BANNER
    ----------------------------------------------------------------
    Oracle Database 10g Express Edition Release 10.2.0.1.0 - Product
    PL/SQL Release 10.2.0.1.0 - Production
    CORE 10.2.0.1.0 Production
    TNS for 32-bit Windows: Version 10.2.0.1.0 - Production
    NLSRTL Version 10.2.0.1.0 - Production


    Tu crois que c'est parce que c'est une XE?

  6. #6
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 950
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 950
    Points : 5 849
    Points
    5 849
    Par défaut
    Que donne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    desc sys.odcivarchar2list

  7. #7
    Membre du Club
    Inscrit en
    Mars 2006
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 113
    Points : 48
    Points
    48
    Par défaut
    Voilà m'sieur:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    desc sys.odcivarchar2list
    user type definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             
    -----------------------------------------------------------
    TYPE ODCIVarchar2List                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            
     AS VARRAY(32767) OF VARCHAR2(4000);

  8. #8
    Membre du Club
    Inscrit en
    Mars 2006
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 113
    Points : 48
    Points
    48
    Par défaut
    Salut skuatamad,

    je viens de tester en "conditions réelles", c'est à dire sur une vraie base, avec un vrai Oracle, et magie, ça marche du feu de dieu !

    Merci infiniment !

    Philippe

  9. #9
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 950
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 950
    Points : 5 849
    Points
    5 849
    Par défaut
    Sur une 11GXE ça marche (je ne sais pas pour la 10GXE):
    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
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    SQL> create table PERSONNES (nom varchar2(20), liste_rel clob)
      2  /
     
    Table created.
     
    SQL> insert into PERSONNES values ('NOM1', 'REL11
      2  REL12
      3  REL13')
      4  /
     
    1 row created.
     
    SQL> insert into PERSONNES values ('NOM2', 'REL21
      2  REL22
      3  REL23')
      4  /
     
    1 row created.
     
    SQL> select * from personnes
      2  /
     
    NOM                  LISTE_REL
    -------------------- ------------------------------
    NOM1                 REL11
                         REL12
                         REL13
     
    NOM2                 REL21
                         REL22
                         REL23
     
     
    SQL> SELECT t.nom, x.column_value AS liste_rel
      2    FROM personnes t
      3   CROSS JOIN TABLE(
      4               cast(multiset(
      5                       SELECT substr( chr(10)||liste_rel||chr(10),
      6                                     instr( chr(10)||liste_rel||chr(10), chr(10), 1, rownum )+1,
      7                                     instr( chr(10)||liste_rel||chr(10), chr(10), 1, rownum+1 )
      8                                     -instr( chr(10)||liste_rel||chr(10), chr(10), 1, rownum )-1
      9                                    )
     10                         FROM dual
     11                      connect BY level <= length(liste_rel)-length(REPLACE(liste_rel,chr(10),''))+1
     12                            ) AS sys.odcivarchar2list )
     13                         ) x
     14  /
     
    NOM                  LISTE_REL
    -------------------- ------------------------------
    NOM1                 REL11
    NOM1                 REL12
    NOM1                 REL13
    NOM2                 REL21
    NOM2                 REL22
    NOM2                 REL23
     
    6 rows selected.
     
    SQL> select * from v$version;
     
    BANNER
    --------------------------------------------------------------------------------
    Oracle Database 11g Express Edition Release 11.2.0.2.0 - Production
    PL/SQL Release 11.2.0.2.0 - Production
    CORE    11.2.0.2.0      Production
    TNS for 32-bit Windows: Version 11.2.0.2.0 - Production
    NLSRTL Version 11.2.0.2.0 - Production
     
    SQL>

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

Discussions similaires

  1. affichage variable avec retour chariot
    Par swissmade dans le forum Langage
    Réponses: 1
    Dernier message: 19/03/2007, 19h02
  2. Format Text avec retour chariot
    Par Poisson59 dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 18/01/2007, 13h34
  3. Export champ 'text' avec retour chariot
    Par wizdom dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 22/09/2006, 16h02
  4. decompte avec retour chariot
    Par taka10 dans le forum Général JavaScript
    Réponses: 8
    Dernier message: 23/08/2006, 15h31
  5. afficher texte avec retour chariot aprèq requète sql
    Par frenchy371 dans le forum Requêtes
    Réponses: 2
    Dernier message: 07/01/2004, 17h33

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