13

我是 Oracle 的新手,而且我 - 也许微不足道 - 选择中的一个问题。(我使用的是 Oracle 10g 快捷版)。

我有一个带有字段 CLOB 的数据库:mytab.xml 此列有一个这样的 XML:

<?xml version="1.0" encoding="iso-8859-1"?>
<info>
<id> 954 </id>
<idboss> 954 </idboss>
<name> Fausto </name>
<sorname> Anonimo </sorname>
<phone> 040000000 </phone>
<fax> 040000001 </fax>
</info>

我正在尝试进行“简单”选择以获取例如“传真”标签的值。但我有一点问题,我无法理解我的错误。例如:

select extract(xml, '//fax').getStringVal() from mytab;
ORA-00932: inconsistent datatypes: expected - got

select extract(xmltype(xml), '//fax').getStringVal() from mytab;
ORA-06502: PL/SQL: numeric or value error
ORA-06512: at "SYS.XMLTYPE", line 254

我也尝试过使用“extractvalue”,但我遇到了同样的问题。我在哪里做错了?

4

7 回答 7

30

试试这个:

select xmltype(t.xml).extract('//fax/text()').getStringVal() from mytab t
于 2011-02-03T09:46:08.997 回答
3

尝试使用xmltype.createxml(xml).

如中,

select extract(xmltype.createxml(xml), '//fax').getStringVal() from mytab;

它对我有用。

如果您想进一步改进或操纵。

尝试这样的事情。

Select *
from xmltable(xmlnamespaces('some-name-space' as "ns", 
                                  'another-name-space' as "ns1",
                           ), 
                    '/ns/ns1/foo/bar'
                    passing xmltype.createxml(xml) 
                    columns id varchar2(10) path '//ns//ns1/id',
                            idboss varchar2(500) path '//ns0//ns1/idboss',
                            etc....

                    ) nice_xml_table

希望它可以帮助某人。

于 2012-02-20T21:50:54.567 回答
0

这个查询在我的情况下运行完美

select xmltype(t.axi_content).extract('//Lexis-NexisFlag/text()').getStringVal() from ax_bib_entity t
于 2013-05-29T11:32:28.557 回答
0

您可以通过以下查询来实现

  1. select extract(xmltype(xml), '//fax/text()').getStringVal() from mytab;

  2. select extractvalue(xmltype(xml), '//fax') from mytab;

于 2014-04-11T13:03:56.190 回答
0

您可以尝试从 CLOB XML 创建 DBMS_XMLPARSER.parser 对象并从中获取 DBMS_XMLDOM.DOMDocument 对象。然后使用 DBMS_XMLDOM 封装方法获取任意节点的值。

   xml_            CLOB := 'X';
   p               DBMS_XMLPARSER.parser;
   doc_            DBMS_XMLDOM.DOMDocument;

      -- Convert the CLOB into a XML-document
      P := DBMS_XMLPARSER.newparser();
      -- Parse the clob and get the XML-document
      DBMS_XMLPARSER.parseclob(p, xml_);
      doc_ := DBMS_XMLPARSER.getDocument(p);

然后使用以下方法提取节点值

DBMS_XMLDOM.getElementsByTagName(doc_, 'NodeName'); DBMS_XMLDOM.GetNodeValue(node_obj_);

在此处参考有关 DBMS_XMLDOM 方法的更多信息。

于 2016-06-16T07:11:01.437 回答
0

的情况下 :

<?xml version="1.0" encoding="iso-8859-1"?>
<info xmlns="http://namespaces.default" xmlns:ns2="http://namespaces.ns2" >
    <id> 954 </id>
    <idboss> 954 </idboss>
    <name> Fausto </name>
    <sorname> Anonimo </sorname>
    <phone> 040000000 </phone>
    <fax> 040000001 </fax>
</info>

询问 :

Select *
from xmltable(xmlnamespaces(default 'http://namespaces.default'
                              'http://namespaces.ns2' as "ns",
                       ), 
                '/info'
                passing xmltype.createxml(xml) 
                columns id varchar2(10) path '/id',
                        idboss varchar2(500) path '/idboss',
                        etc....

                ) nice_xml_table
于 2017-03-08T11:44:37.887 回答
0

如果 XML 存储在数据库表的 CLOB 字段中。例如对于这个 XML:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<Awmds>
    <General_segment>
        <General_segment_id>
        <Customs_office_code>000</Customs_office_code>
    </General_segment_id>
</General_segment>
</Awmds>

这是提取查询:

SELECT EXTRACTVALUE (
    xmltype (T.CLOB_COLUMN_NAME),
    '/Awmds/General_segment/General_segment_id/Customs_office_code')
    AS Customs_office_code
FROM TABLE_NAME t;
于 2020-08-10T06:05:45.897 回答