1

我尝试在目录中打印第 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 />
4

1 回答 1

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(...)根据需要申请,但我猜它不会产生您期望的结果)。

于 2015-10-07T15:11:09.760 回答