gpt4 book ai didi

sql - 即使表达式值为空,如何强制执行 xmlforest creat 元素?

转载 作者:数据小太阳 更新时间:2023-10-29 02:22:13 27 4
gpt4 key购买 nike

我想使用 oracle XMLFOREST 函数。 ( Link for definition )

示例语法:

XMLFOREST( [value expression AS alias], [...])

我的问题是,如果值表达式为 NULL,则不会为该值表达式创建任何元素。

我如何强制它添加一个空的 XML 片段?

最佳答案

您不能使用 XMLFOREST :

If value_expr is null, then no element is created for that value_expr.

也不是类似的XMLCOLATTVAL功能:

You must specify a value for value_expr. If value_expr is null, then no element is returned.

XMLELEMENT另一方面按要求返回一个空元素:

SQL> select xmlelement("EMP", xmlelement("ENAME", ename), 
2 xmlelement("JOB", job),
3 xmlelement("MGR", mgr)
4 ).getclobval() xml
5 from scott.emp;

XML
----------------------------------------------------------------
<EMP><ENAME>KING</ENAME><JOB>PRESIDENT</JOB><MGR></MGR></EMP>
<EMP><ENAME>BLAKE</ENAME><JOB>MANAGER</JOB><MGR>7839</MGR></EMP>
...

为了完整性,还可以使用另外两个 Oracle 工具(受 this post on the OTN forums 启发)。首先你可以使用 XMLQUERY (在 11.2 上?):

SQL> select
2 xmlquery(
3 '(#ora:view_on_null empty #) {
4 <EMPS> {
5 for $c in fn:collection("oradb:/SCOTT/EMP")/ROW
6 return element EMP {
7 $c/ENAME
8 , $c/JOB
9 , $c/MGR
10 }
11 }</EMPS>
12 }'
13 passing cast(10 as number) as "mid"
14 returning content
15 ).getClobval() as result
16 from dual;

RESULT
----------------------------------------------------------------------
<EMPS>
<EMP><ENAME>KING</ENAME><JOB>PRESIDENT</JOB><MGR></MGR></EMP>
<EMP><ENAME>BLAKE</ENAME>...

您还可以使用 DBMS_XMLGEN包裹:

SQL> DECLARE
2 ctx dbms_xmlgen.ctxHandle;
3 sqlstr varchar2(4000)
4 := 'SELECT ename, job, mgr FROM scott.emp WHERE ename=''KING''';
5 res clob;
6 BEGIN
7 ctx := dbms_xmlgen.newContext(sqlstr);
8 dbms_xmlgen.setNullHandling(ctx, dbms_xmlgen.EMPTY_TAG);
9 res := dbms_xmlgen.getXML(ctx);
10 dbms_xmlgen.closeContext(ctx);
11 dbms_output.put_line(res);
12 END;
13 /

<?xml version="1.0"?>
<ROWSET>
<ROW>
<ENAME>KING</ENAME>
<JOB>PRESIDENT</JOB>
<MGR/>
</ROW>
</ROWSET>

关于sql - 即使表达式值为空,如何强制执行 xmlforest creat 元素?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15705800/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com