1
A
回答
0
函数用于创建零XML元素,我相信它可以改进:
create function add_xml_element(
p_name in varchar2,
p_value in varchar2,
p_namespaces in varchar2 default null,
p_nil_prefix in varchar2 default null,
p_nil_namespace in varchar2 default null) return XMLType is
l_result XMLType;
begin
if p_value is not null then
l_result := XMLType('<' || p_name || ' ' || p_namespaces || '>'||p_value||'</' || p_name || '>');
elsif p_nil_prefix is not null and p_nil_namespace is not null then
l_result := XMLType('<' || p_name || ' ' || p_namespaces || ' ' || p_nil_namespace || ' ' || p_nil_prefix || ':nil="true"/>');
else
raise_application_error(-20001, 'Nil prefix or namespace not provided');
end if;
return l_result;
end;
和PLSQL脚本来测试它:
declare
l_xml xmlType;
cursor c_build_xml(cp_value in varchar2) is
select
xmlElement("root",
add_xml_element(
'node',
cp_value,
null,
'i',
'xmlns:i="default"'))
from
dual;
begin
open c_build_xml('nodevalue');
fetch c_build_xml
into l_xml;
close c_build_xml;
dbms_output.put_line(l_xml.getClobVal());
open c_build_xml(null);
fetch c_build_xml
into l_xml;
close c_build_xml;
dbms_output.put_line(l_xml.getClobVal());
end;
/
脚本输出如下:
<root>
<node>nodevalue</node>
</root>
<root>
<node xmlns:i="default" i:nil="true"/>
</root>
相关问题
- 1. 如何在ORACLE 11g中参照给定的XSD生成XML?
- 2. 如何在Oracle中生成GUID?
- 3. 如何在Oracle中生成排列?
- 4. 在oracle视图中生成随机值
- 5. 如何在oracle表中处理空值
- 6. 如何从Oracle数据库中的对象类型生成XML
- 7. 如何在XSLT中动态生成名称空间XML属性?
- 8. 如何生成XML?
- 9. 如何生成XML
- 10. 生成XML命名空间
- 11. 如何在Coldfusion中生成.xml文件?
- 12. 在Oracle中生成报告?
- 13. 如何在内部生成oracle rowid?
- 14. Oracle SQL生成嵌套的xml
- 15. 使用Oracle SQL生成嵌套的XML
- 16. 从自引用Oracle生成XML表
- 17. 使用java生成Oracle报告xml
- 18. 如何打印由Oracle生成的大型XML字符串?
- 19. 如何从Oracle ADF生成有效的xhtml/xml输出
- 20. 如何为数据集中为空的数据表生成XML?
- 21. 如何设置为空值在Oracle SQL
- 22. 如何动态生成XML?
- 23. 如何生成XML报告?
- 24. 如何生成以下xml
- 25. 如何从C#生成XML?
- 26. 如何从关键值配对xml中生成名称值对的xml?
- 27. 如何使用本机Oracle XML DB Web服务删除空值?
- 28. 如何使用Oracle在表中获取XML空标记的虚拟值?
- 29. 如何用Perl的XML :: Simple生成XML?
- 30. 如何在MonoTouch上生成XML?