sql >> Database >  >> RDS >> Oracle

Hoe retourneer ik een lijst met waarden in plaats van een tekenreeks bij het opvragen van een Oracle-database met XPath?

EXTRACT (en EXTRACTVALUE ) zijn verouderde functies. Gebruik XMLTABLE in plaats daarvan:

with sample_data as (select xmltype('<film>
    <title>Godfather, The</title>
    <year>1972</year>
    <directors>
        <director>Francis Ford Coppola</director>
    </directors>
    <genres>
        <genre>Crime</genre>
        <genre>Drama</genre>
    </genres>
    <plot>Son of a mafia boss takes over when his father is critically wounded in a mob hit.</plot>
    <cast>
        <performer>
            <actor>Marlon Brando</actor>
            <role>Don Vito Corleone</role>
        </performer>
        <performer>
            <actor>Al Pacino</actor>
            <role>Michael Corleone</role>
        </performer>
        <performer>
            <actor>Diane Keaton</actor>
            <role>Kay Adams Corleone</role>
        </performer>
        <performer>
            <actor>Robert Duvall</actor>
            <role>Tom Hagen</role>
        </performer>
        <performer>
            <actor>James Caan</actor>
            <role>Sonny Corleone</role>
        </performer>
    </cast>
</film>') x from dual)
select x.*
from   sample_data sd,
       xmltable('/film[title="Godfather, The"]/cast/performer' passing sd.x
                columns actor varchar2(50) path '//actor',
                        role varchar2(50) path '//role') x;

ACTOR                                              ROLE                                              
-------------------------------------------------- --------------------------------------------------
Marlon Brando                                      Don Vito Corleone                                 
Al Pacino                                          Michael Corleone                                  
Diane Keaton                                       Kay Adams Corleone                                
Robert Duvall                                      Tom Hagen                                         
James Caan                                         Sonny Corleone  

(Ik heb de rolkolom alleen voor aanvullende informatie toegevoegd; u zou die kolom gewoon uit de kolomlijst in de XMLTABLE verwijderen deel als u het niet hoeft te zien.)




  1. SQL SELECT met m:n-relatie

  2. hoe weet ik of de kolom de primaire sleutel is met mysqli?

  3. Postgres kan geen verbinding maken met de server op Unix-domein socket 5432

  4. python pip install psycopg2 installatiefout