返回多个数据元素

时间:2011-05-13 05:09:13

标签: xquery

使用Xquery,我如何搜索下面的文件(由许多项组成),对于所有在部件编号中有“XC”的项目(有很多),然后对于匹配返回所有3个有趣的数据元素(部件号,部件名和名称)?返回是主要问题 - 我的尝试导致有趣的数据元素的每个排列。谢谢!

    
<catalog>
   <item>
     <description>
    <partref>
       <part-id>
        <part-number>XC51222</part-number>
       </part-id>
    </partref>
    <part-name>DSP, Network Vectoring<part-name>
    <vendors>
       <vendor1>
        <pay-to>
           <name>JCOF Industries</name>
        </pay-to>
       </vendor1>
    </vendors>
      </description>
   </item>
   <item>
   </item>
[many items…]
</catalog>

1 个答案:

答案 0 :(得分:0)

xquery version "1.0";

let $sep := ','
for $x in catalog/item
where fn:matches($x/description/partref/part-id/part-number, 'XC')
return fn:string-join( ($x/description/partref/part-id/part-number/text(), $x/description/part-name/text(), $x/description/vendors/vendor1/pay-to/name/text()), $sep)