我尝试在目录中打印第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 />
答案 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(...)
,但我猜它不会产生您期望的结果。)