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


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

例如,假定声明了 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表达式--路径表达式--指定路径表达式中的谓词

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值