相关疑难解决方法(0)

在xml(Oracle)中使用命名空间时如何通过xmltable解析xml

我想解析一个xml字符串,它是从servier发送的Web服务响应,xml如下所示:

<?xml version="1.0" encoding="utf-8"?>
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
    <soap:Body>
        <addResponse xmlns="http://tempuri.org/">
            <addResult>20</addResult>
        </addResponse>
    </soap:Body>
</soap:Envelope>
Run Code Online (Sandbox Code Playgroud)

我想在元素addResult之间获得值20.我的plsql代码段如下所示:

declare
  v_xml clob;
begin
  v_xml := '<?xml version="1.0" encoding="utf-8"?>
  <soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
    <soap:Body>
      <addResponse xmlns="http://tempuri.org/">
        <addResult>20</addResult>
      </addResponse>
    </soap:Body>
  </soap:Envelope>';
  for c in (select results 
        from xmltable('Envelope/Body/addResponse' passing xmltype(v_xml) 
        columns results varchar(100) path './addResult')
       )
  loop
    dbms_output.put_line('the result of calculation is : ' || c.results);
  end loop;
end;
Run Code Online (Sandbox Code Playgroud)

似乎没有打印出任何东西,但是如果我删除命名空间'soap',代码运行良好,那么任何人都能告诉我当xml具有命名空间时如何获得值20?

xml oracle plsql

4
推荐指数
1
解决办法
1万
查看次数

在Oracle中选择xml元素值

我试图从位于Oracle表的XMLTYPE列中的xml元素中提取值.我想要提取的xml元素具有为其定义命名空间的父元素.xml看起来像:

<a>
  <b xmlns="urn:www.someSite.com/myModel">
    <c>my value</c>
  </b>
</a>
Run Code Online (Sandbox Code Playgroud)

如果我想提取"a"元素的内容,则正确返回其上下文:

SELECT Extract(myColumn, '/a') FROM myTable;
Run Code Online (Sandbox Code Playgroud)

但是为了返回"c"元素的内容,我没有成功找到任何版本.以下说明不起作用:

SELECT Extract(myColumn, '/a/b/c') FROM myTable;

SELECT Extract(myColumn, '/a/b/c', 'xmlns="urn:www.someSite.com/myModel"') FROM myTable;

SELECT Extract(myColumn, '/a/b/c', 'urn:www.someSite.com/myModel') FROM myTable;
Run Code Online (Sandbox Code Playgroud)

任何人都能帮助我,使用在这种情况下可行的提取语句吗?

xml oracle namespaces extract

2
推荐指数
1
解决办法
1万
查看次数

标签 统计

oracle ×2

xml ×2

extract ×1

namespaces ×1

plsql ×1