2
<wbi:appData>
    <wbi:content wbi:name="1st_status">
        <wbi:value xsi:type="xsd:string">Success</wbi:value>
        </wbi:content>
    </wbi:appData>
</wbi:event>

我需要使用 SQL 开发人员获取第 2 行中的值“1st_status”和第 3 行中的“Success”。

此 xml 位于一个表中,该表具有 CLOB 类型的列。

4

2 回答 2

2

你这样做:

(即表yourdata包含一个clob列c

SQL> select extractvalue(xmltype(c), '/wbi:event/wbi:appData/wbi:content/@wbi:name','xmlns:wbi="http://foo"') name,
  2         extractvalue(xmltype(c), '/wbi:event/wbi:appData/wbi:content/wbi:value','xmlns:wbi="http://foo"') status
  3    from yourdata
  4  /

NAME            STATUS
--------------- ---------------
1st_status      Success

这假设你 wbi 命名空间是 xmlns:wbi="http://foo"

如果 //content 是一个重复的标签,那么你可以这样做:

SQL> select extractvalue(value(t), '/wbi:content/@wbi:name','xmlns:wbi="http://foo"') name,
 2         extractvalue(value(t), '/wbi:content/wbi:value','xmlns:wbi="http://foo"') status
 3    from yourdata,
 4         table(xmlsequence(extract(xmltype(c), '/wbi:event/wbi:appData/wbi:content', 'xmlns:wbi="http://foo"'))) t
 5
SQL> /

NAME            STATUS
--------------- ---------------
1st_status      Success
2nd_status      Failure
于 2012-12-13T10:41:54.453 回答
0

你可以试试 ::

SELECT extractvalue(xmltype(xmlcol), 'xpath') FROM yourtable

但需要检查 xmltype 是否适用于 CLOB 数据类型。

于 2012-12-13T08:38:01.550 回答