作者热门文章
- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我有一个像这样的简单 xml:
<Parameters>
<Parameter>
<Index>0</Index>
<Name>Date</Name>
<Value>@Today</Value>
</Parameter>
<Parameter>
<Index>1</Index>
<Name>Id</Name>
<Value>22</Value>
</Parameter>
</Parameters>
我想遍历每个参数,如果值以“@”开头,则调用一个函数,该函数将值作为参数并返回一个新值。
使用新值更新 xml。
我找到了如何使用 updatexml,但没有运气如何实现我的场景。
最佳答案
您可以通过每个参数节点循环执行此操作,通过函数更改值(我的代码中的内部 CheckXmlValue
)-
declare
cur_xml sys_refcursor;
v_val varchar2(3000);
n_val varchar2(3000);
xml_ XMLType := XMLType(
'<Parameters>
<Parameter>
<Index>0</Index>
<Name>Date</Name>
<Value>@Today</Value>
</Parameter>
<Parameter>
<Index>1</Index>
<Name>Id</Name>
<Value>22</Value>
</Parameter>
</Parameters>'
);
function CheckXmlValue(val_ in varchar2) return varchar2 is
begin
return
case lower(val_)
when '@today' then to_char(sysdate, 'dd/mm/yyyy')
when '@yesterday' then to_char(sysdate-1, 'dd/mm/yyyy')
else val_
end;
end;
begin
open cur_xml for
select extractValue(column_value, '//Value') str
from table(XMLSequence(extract(xml_, '/Parameters/Parameter')));
loop
fetch cur_xml into v_val;
n_val := CheckXmlValue(v_val);
exit when cur_xml%notfound;
select updateXml (
xml_,
'//Parameters/Parameter/Value[text()="'||v_val||'"]/text()',
n_val
)
into xml_
from DUAL;
end loop;
close cur_xml;
-- result:
dbms_output.put_line(xml_.extract('*').getStringVal());
end;
/
关于xml - 检查 XMLType 节点值并在必要时更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34153979/
我正在使用 this solution在二进制矩阵中找到与图像边界对齐的矩形。假设现在我想找到一个不与图像边框对齐的矩形,并且我不知道它的方向;找到它的最快方法是什么? 为了示例,让我们寻找一个仅包含
else: 行在这个 Python 程序中是否正确/必要? from random import randrange for n in range(10): r = randrange(0,1
在 TDPL 7.1.5.1 中讨论了将 Widget w2 分配给 w1 并且作者指出“将 w2 逐个字段分配给 w1 会将 w2.array 分配给 w1.array——一个简单的数组边界分配,而
我是一名优秀的程序员,十分优秀!