这是我的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>'
);
答案 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