XML标记值从Clob列中提取,Oracle中具有相同名称的多个标记

时间:2016-07-04 10:15:06

标签: xml oracle plsql

这是我的clob数据

<id>ID001</id>
<atrbtList>
    <Atrbts>
        <atrTyp>1</atrTyp>
        <atrVal>04120101254</atrVal>
    </Atrbts>
    <Atrbts>
        <atrTyp>2</atrTyp>
        <atrVal>1254</atrVal>
    </Atrbts>
</atrbtList>

在表格中。

我需要以

的形式提取数据
ID    |Type |Value 
------------------
ID001 | 1   |04120101254
ID001 | 2   |1254

目前我正在使用oracle xml提取功能,这就是我已经查询了

    SELECT 
        XMLTYPE(xml_clob).extract('//id/text()').getStringVal() AS Id,
        EXTRACTVALUE( s1.COLUMN_VALUE, '//atrTyp' ) AS AtrTyp,
        EXTRACTVALUE( s.COLUMN_VALUE, '//atrVal' ) AS AtrVal
    FROM   table_name T,
           TABLE(
             XMLSequence(
               EXTRACT(
                 XMLType( T.xml_clob ),
                 '//atrVal'
               )
             )
           ) s,
           TABLE(
             XMLSequence(
               EXTRACT(
                 XMLType( T.xml_clob ),
                 '//atrTyp'
               )
             )
           ) s1

,这会产生结果集

ID    |Type |Value 
------------------
ID001   1   04120101254
ID001   2   04120101254
ID001   1   1254
ID001   2   1254

有没有人能指出我正确的方向来获得理想的结果,我也觉得可以改进查询,或者有更好的方法去做我想要的。

PS: 表及其内容

CREATE TABLE table_name (xml_clob CLOB );

INSERT INTO table_name VALUES ( 
'<data><id>ID001</id><atrbtList><Atrbts><atrTyp>1</atrTyp><atrVal>04120101254</atrVal></Atrbts><Atrbts><atrTyp>2</atrTyp><atrVal>1254</atrVal></Atrbts></atrbtList></data>'
);

1 个答案:

答案 0 :(得分:0)

你正在做交叉连接2x2 = 4.你应该得到atrbtList作为表(Atrbts的序列):

 SELECT XMLTYPE(xml_clob).extract('//id/text()').getStringVal() AS Id,
        EXTRACTVALUE( s.COLUMN_VALUE, '/Atrbts/atrTyp' ) AS AtrTyp,
        EXTRACTVALUE( s.COLUMN_VALUE, '/Atrbts/atrVal' ) AS AtrVal
    FROM   table_name T,
           TABLE(
             XMLSequence(
               EXTRACT(
                 XMLType( T.xml_clob ),
                 '/data/atrbtList/*'
               )
             )
           ) s