如何从Oracle数据库中的Object Type生成XML
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何从Oracle数据库中的Object Type生成XML相关的知识,希望对你有一定的参考价值。
正如标题所解释的,如何将Oracle中对象类型的数据解析为XML格式?
例如,如果我有一个对象类型CUSTOMER,那么如何将数据从该对象的实例转换为XML文本?
答案
首先,您创建了对象类型:
CREATE TYPE CUSTOMER AS OBJECT
(NAME VARCHAR2(100));
它必须转换为XMLTYPE
,然后您将能够使用getstringval
函数从中获取XML文本。
DECLARE
v_customer CUSTOMER;
v_xml XMLTYPE;
BEGIN
v_customer:= NEW CUSTOMER('Josh');
v_xml := XMLTYPE(v_customer);
DBMS_OUTPUT.put_line(v_xml.getstringval);
END;
这将产生以下输出:
<CUSTOMER><NAME>Josh</NAME></CUSTOMER>
另一答案
你可以使用SYS_XMLGEN
SELECT SYS_XMLGEN(v_customer, XMLFormat(enclTag =>'CUSTOMER'))
INTO v_xml
FROM dual;
不太方便使用..但也支持TABLE OF ...类型,并且“漂亮打印”以在文本中包含新行
即
DECLARE
v_customer CUSTOMER;
v_xml XMLTYPE;
BEGIN
v_customer:= NEW CUSTOMER('Josh');
SELECT SYS_XMLGEN(v_customer, XMLFormat(enclTag =>'CUSTOMER'))
INTO v_xml
FROM dual;
DBMS_OUTPUT.put_line(v_xml.getstringval);
END;
/
<?xml version="1.0"?>
<CUSTOMER>
<NAME>Josh</NAME>
</CUSTOMER>
create type tab_of_cust as TABLE OF CUSTOMER;
DECLARE
v_customer CUSTOMER;
v_xml XMLTYPE;
v_tab tab_of_cust := tab_of_cust();
BEGIN
v_customer:= NEW CUSTOMER('Josh');
v_tab.extend(1);
v_tab(1) := v_customer;
SELECT SYS_XMLGEN(v_tab, XMLFormat(enclTag =>'CUST_TAB'))
INTO v_xml
FROM dual;
DBMS_OUTPUT.put_line(v_xml.getstringval);
END;
/
<?xml version="1.0"?>
<CUST_TAB>
<CUSTOMER>
<NAME>Josh</NAME>
</CUSTOMER>
</CUST_TAB>
以上是关于如何从Oracle数据库中的Object Type生成XML的主要内容,如果未能解决你的问题,请参考以下文章
Oracle 如何知道那个表用到哪个序列?急急急急急急急急急.....