$a是
(<pet name="a1">
<age num="1"/>
</pet>,
<pet name="a2">
<age num="2"/>
</pet>)$b是
(<pet name="a2">
<age num="9"/>
</pet>,
<pet name="a3">
<age num="11"/>
</pet>
<pet name="a3">
<age num="14"/>
</pet>)
我试图获得以下输出( $a中的所有内容和$b中的所有内容,除了已经打印出来的输出),即,
(<pet name="a1">
<age num="1"/>
</pet>,
<pet name="a2">
<age num="2"/>
</pet>,
<pet name="a3">
<age num="11"/>
<age num="14"/>
</pet>)由于<pet name="a2">已经从$a中打印出来,所以必须跳过$b中具有相同属性的相同元素,所以我在xquery中尝试了下面的代码,但无法获得所需的结果。
for $l in $a
for $m in $b
return if ($m/@name!=$l/@name)发布于 2014-10-12 19:52:56
通过加入序列并使用谓词表达式过滤第二个序列,可以更简单地不使用循环来解决这个问题:
($a | $b[not(@name = $a/@name)])https://stackoverflow.com/questions/26329274
复制相似问题