在Oracle DB

时间:2015-07-14 14:33:41

标签: xml oracle xmlspy

我是DBAdministration的新手,我被要求从大(8Gb)xml文件开始设计db结构。 我正在构建这个结构,它几乎已经完成了。

我正在测试将XML中的数据导入表中。 我已将文件的内容存储到表中的列中,但是当我尝试导出一个列值时,我没有结果(并且没有错误)。

这里是代码:

CREATE TABLE TESTTABLE2 ( xml_file XMLTYPE ) XMLTYPE xml_file STORE as securefile binary xml;

INSERT INTO TESTTABLE2 (xml_file) 
(SELECT XMLTYPE(bfilename('EXPORT_DUMPS','test001.xml'), nls_charset_id('WE8ISO8859P1')) from dual );


SELECT 'CD_UID'
FROM XMLTABLE('XML/records/REC/UID' passing (SELECT xml_file FROM TESTTABLE2) 
           COLUMNS CD_UID VARCHAR2(4000));           

XML以这样的方式开始:

<?xml version="1.0" encoding="UTF-8"?> 

<records xmlns="http://xxxxxxxxxxxxxx">

<REC r_id_disclaimer="yyyyy">
<UID>UID_number</UID>

我还尝试直接从XML文件中提取所有数据,我使用以下代码将其存储在Oracle服务器中的文件夹中: 它也可以,但没有插入行。

INSERT INTO TESTTABLE(CD_UID)
WITH t AS (SELECT xmltype(bfilename('EXPORT_DUMPS','test001.xml'), nls_charset_id('WE8ISO8859P1')) xmlcol FROM dual)
SELECT
extractValue(value(x),'REC/UID') as CD_UID           
FROM t,TABLE(XMLSequence(extract(t.xmlcol,'/records/REC'))) x;

我也想知道XML文件的结构是否对导入过程有任何影响。我的意思是:在我的结构中,我有一个代码,它指的是另一个表中的值,但在XML中我直接有值名称。)

我也尝试使用XMLSpy尝试转换和导出到数据库,但它不会在表之间创建任何关系。

在这里有人可以帮助我找到解决方案并开车通过吗?

非常感谢!

1 个答案:

答案 0 :(得分:0)

您可以使用an XMLTable clause以关系形式获取数据:

select x.cd_uid
from testtable2 t
cross join xmltable(xmlnamespaces(default 'http://xxxxxxxxxxxxxx'),
  '/records/REC'
  passing t.xml_file 
  columns cd_uid varchar2(20) path 'UID'
) x;

CD_UID             
--------------------
UID_number          

您在records节点中有一个名称空间,因此您需要通过xmlnamespaces子句包含该名称空间;因为你只有一个我已经使它成为默认值,所以你不必通过对它的引用来混淆XPath。