指定路径表达式步骤中的谓词

来源:互联网 发布:淘宝虚拟男友 编辑:程序博客网 时间:2024/05/21 09:03


谓词通过应用指定的测试来筛选节点序列。谓词表达式用方括号括起来并绑定到路径表达式中的最后一个节点。

例如,假定声明了 xml 数据类型的 SQL 参数值 (x),如下所示:

declare @x xmlset @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表达式--路径表达式--指定路径表达式中的谓词