2011-02-03 118 views
10

我是Oracle新手,我已经 - 可能很平凡 - select中存在问题。 (我正在使用Oracle 10g Express Edition)。Oracle 10g:从XML中提取数据(选择)(CLOB类型)

我有一个DB与现场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',但我也遇到同样的问题。 我在哪里做错了?

回答

27

试试这个:

select xmltype(t.xml).extract('//fax/text()').getStringVal() from mytab t 
+0

尚未:ORA-06502:PL/SQL:数字或值错误 ORA-06512:在 “SYS.XMLTYPE”, line 254 ORA-06512:at line 1 – mymark 2011-02-03 10:02:29

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 

希望它可以帮助别人。

0

此查询我的情况完全运行

select xmltype(t.axi_content).extract('//Lexis-NexisFlag/text()').getStringVal() from ax_bib_entity t 
0

你可以用下面的查询实现

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

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

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_, '节点名'); DBMS_XMLDOM.GetNodeValue(node_obj_);

请参阅关于DBMS_XMLDOM方法here的更多信息。

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 
相关问题