在xquery中从主根查找相同的节点值

时间:2013-11-28 10:22:19

标签: xml xquery altova

p.xml

<documents>
  <dblp>
    <inproceedings>
      <author>John Cieslewicz</author>
      <author>Kenneth A. Ross</author>
      <author>Kenneth A. Ross</author>
    </inproceedings>
   </dblp>
   <dblp>
    <inproceedings>
      <author>Yi-Reun Kim</author>
      <author>Kyu-Young Whang</author>
      <author>John Cieslewicz</author>
    </inproceedings>
   </dblp>
 <documents>

我的代码是

for $c in doc("C:\Users\User\Desktop\p.xml")//documents/dblp/inproceedings
where fn:count($c/author) != fn:count(fn:distinct-values($c/author))
return $c/author

我需要 John Cieslewicz Kenneth A. Ross ,但仅显示 Kenneth A. Ross

1 个答案:

答案 0 :(得分:1)

如果要列出多次出现的作者,您需要在所有作者列表中全局计算,而不是在诉讼作者列表中本地计算:

let $docs := doc("C:\Users\User\Desktop\p.xml")/documents, 
    $authors := $docs//author,
    $distinct-authors := distinct-values($authors)
for $author in $distinct-authors
where count($authors[. eq $author]) > 1 
return $author