谓词通过应用指定的测试来筛选节点序列。谓词表达式用方括号括起来并绑定到路径表达式中的最后一个节点。
例如,假定声明了 xml 数据类型的 SQL 参数值 (x),如下所示:
declare @x xml
set @x = '
<People>
<Person>
<Name>John</Name>
<Age>24</Age>
</Person>
<Person>
<Name>Goofy</Name>
<Age>54</Age>
</Person>
<Person>
<Name>Daffy</Name>
<Age>30</Age>
</Person>
</People>
'
在这种情况下,下表达式是有效的,它们在三个不同节点级别使用谓词值 [1]。
select @x.query('/People/Person/Name[1]')
select @x.query('/People/Person[1]/Name')
select @x.query('/People[1]/Person/Name')
请注意,在每种情况下,谓词都绑定到应用该谓词的路径表达式中的节点。例如,第一个路径表达式选择每个 /People/Person 节点中的第一个 <Name
> 元素,然后使用提供的 XML 实例返回下列内容:
<Name>John</Name><Name>Goofy</Name><Name>Daffy</Name>
但是,第二个路径表达式选择第一个 /People/Person 节点下的所有 <Name
> 元素。因此,它将返回下列内容:
<Name>John</Name>
括号还可以用来改变谓词的计算顺序。例如,在下列表达式中,用一组括号来分隔路径 (/People/Person/Name) 和谓词 [1]:
select @x.query('(/People/Person/Name)[1]')
在此示例中,谓词的应用顺序改变了。这是因为首先计算括起来的路径 (/People/Person/Name),然后将谓词 [1] 运算符应用于包含与括起来的路径匹配的所有节点的集合。如果没有括号,运算顺序就会不同,[1] 将应用为 child::Name
节点测试(与第一个路径表达式示例类似)。
转自:SQL Server 2005帮助中XQuery表达式--路径表达式--指定路径表达式中的谓词