我需要在 OSB 流程中进行特定的 XQuery 转换。
输入有这种形式:
<OBJECT_1>
<item> // multiplicy : *
<MONTH>
<INFO_11/>
<INFO_12/>
</item>
</OBJECT_1>
<OBJECT_2>
<item> // multiplicy : *
<INFO_21/>
<INFO_22/>
<MONTH/>
</item>
</OBJECT_2>
目标输出具有以下结构:
<object1> // multiplicy : *
<month>
<info11/>
<info12/>
<object2> // multiplicy : *
<info21/>
<info22/>
</object2>
</object1>
目前我的 xquery 看起来像:
declare function xf:myTransformation($z_SOURCE1 as element(ns1:SOURCE))
as element(ns0:targetService) {
<ns0:targetService>
<myFlow>
{
for $item in $z_SOURCE1/ns1:OBJECT_1/ns1:item
return
<object1>
{
for $MONTH in $item/ns1:MONTH
return
<month>{ data($MONTH) }</month>
}
{
for $INFO_11 in $item/ns1:INFO_11
return
<info11>{ data($INFO_11) }</info11>
}
{
for $INFO_12 in $item/ns1:INFO_12
return
<info12>{ data($INFO_12) }</info12>
}
{
for $item0 in $z_SOURCE1/ns1:OBJECT_2/ns1:item
return
{
for $INFO_21 in $item0/ns1:INFO_21
return
<info21>{ data($INFO_21) }</info21>
}
{
for $INFO_22 in $item0/ns1:INFO_22
return
<info21>{ data($INFO_22) }</info22>
}
</object1>
}
</myFlow>
</ns0:targetService>
};
如您所见,OBJECT_1 和 OBJECT_2 之间没有“匹配”...
如何在 OBJECT_2 中“查找”列出与 object1 月份键匹配的对象(在 SQL 中:)OBJECT_1.MONTH=OBJECT_2.MONTH
?在构建 OBJECT_1 时,我可以走进 OBJECT_2 列表来查找我需要的键吗?