基于XQuery中的位置进行过滤时清空结果

时间:2015-10-07 12:41:58

标签: sql-server xml xquery flwor

我尝试在目录中打印第3和第4个产品的详细信息,但结果却是空白。

XML输入:

<catalog>
  <product dept="WMN">
    <number>557</number>
    <name language="en">Fleece Pullover</name>
    <colorChoices>navy black</colorChoices>
  </product>
  <product dept="ACC">
    <number>563</number>
    <name language="en">Floppy Sun Hat</name>
  </product>
  <product dept="ACC">
    <number>443</number>
    <name language="en">Deluxe Travel Bag</name>
  </product>
  <product dept="MEN">
    <number>784</number>
    <name language="en">Cotton Dress Shirt</name>
    <colorChoices>white gray</colorChoices>
    <desc>Our <i>favorite</i> shirt!</desc>
  </product>
</catalog>

我尝试了什么:

SELECT xDoc.query('  for $prod in //product
let $x:=$prod
return (<Item>{data($x[3])}{data($x[4])}</Item>)') 
FROM  AdminDocs
where  id=6

显示输出:

<Item />
<Item />
<Item />
<Item />

1 个答案:

答案 0 :(得分:3)

这定义了所有产品的循环:

for $prod in //product

对于每个产品,您将从单个产品的序列中返回第三个和第四个节点,这显然会产生空节点:

let $x:=$prod
return (<Item>{data($x[3])}{data($x[4])}</Item>)

为了更好地理解,每次都返回整个产品节点:

for $prod in //product
return <item>{ $prod }</item>

这将导致类似这样的事情:

<item>
  <product dept="WMN">
    <number>557</number>
    <name language="en">Fleece Pullover</name>
    <colorChoices>navy black</colorChoices>
  </product>
</item>
<item>
  <product dept="ACC">
    <number>563</number>
    <name language="en">Floppy Sun Hat</name>
  </product>
</item>
<item>
  <product dept="ACC">
    <number>443</number>
    <name language="en">Deluxe Travel Bag</name>
  </product>
</item>
<item>
  <product dept="MEN">
    <number>784</number>
    <name language="en">Cotton Dress Shirt</name>
    <colorChoices>white gray</colorChoices>
    <desc>Our <i>favorite</i> shirt!</desc>
  </product>
</item>

每个<product/>元素都是$prod[1]。尝试:

for $prod in //product
return <item>{ $prod[1] }</item>

相比,它将返回完全相同的结果
for $prod in //product
return <item>{ $prod[2] }</item>

(或任何其他位置谓词)导致空<item/>个节点。

最后,要仅返回第三个和第四个产品,请将位置谓词转换为for循环参数:

for $prod in //product[position() = 3 or position() = 4]
return <item>{ $prod }</item>

(并根据需要应用data(...),但我猜它不会产生您期望的结果。)

相关问题