1

我从请求中得到以下 XML:

<records>
  <record>
    <field name="code" value="1"/>
    <field name="dexcription" value="MyName"/>
    <field name="id" value="666">
  </record>
  <record>
    <field name="code" value="2"/>
    <field name="dexcription" value="MyName"/>
  </record>
  ...
</records>

第一条记录处理成功,返回元素“id”;第二个不是,所以没有这个元素就返回了。

我需要编写一个基于返回这两列(“code”和“id”)的 XML SQL 查询,但只返回成功处理的记录。我尝试使用 XMLType,但仍然失败。谁能帮我?

在此先感谢,并为我的“谷歌搜索”英语感到抱歉。

4

1 回答 1

1

我找到了解决方案:

SELECT EXTRACT (COLUMN_VALUE, '/record/field[@name="code"]/@value').GETSTRINGVAL () AS CODE,
       EXTRACT (COLUMN_VALUE, '/record/field[@name="id"]/@value').GETSTRINGVAL () AS ID
  FROM TABLE (XMLSEQUENCE (XMLTYPE (:XXML).EXTRACT ('/records/record')))
 WHERE EXTRACT (COLUMN_VALUE, '/record/field[@name="id"]') IS NOT NULL
于 2012-05-31T11:36:56.087 回答