指定路径表达式步骤中的谓词
来源:互联网 发布:淘宝虚拟男友 编辑:程序博客网 时间: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表达式--路径表达式--指定路径表达式中的谓词
- 指定路径表达式步骤中的谓词
- 谓词表达式
- 指定谓词函数排序
- 谓词与lambda表达式
- 正则表达式和谓词
- Objective-c中的谓词
- C++中的谓词函数
- OC中的谓词
- STL中的谓词
- SQL中的谓词
- 谓词,lambda表达式和bind
- iOS-正则表达式与谓词
- HBITMAP加载指定路径中的图片
- Prolog中的表处理谓词
- 正则表达式 取出img标签 保存于指定路径
- 谓词
- 谓词
- 谓词
- mysql安装配置时apply security setting报错
- JSP运行原理和九大隐式对象
- PowerDesigner技巧集6 ---- 用vbscript获取每个汉字中的首字母
- js身份证验证超强脚本
- 什么是 rail-to-rail运算放大器?
- 指定路径表达式步骤中的谓词
- hello,blog
- [IT 男人帮 10/31] TC Disrupt 系列:马化腾谈创业经验和困难
- 聚合拼接字符串的方法
- 强烈推荐没事都看看.
- 透過 OpneNI 讀取 Kinect 深度影像資料
- 关于Javascript中的parseInt()的使用
- Application对象、Session对象和Cookie对象的区别
- ARM掌门:未来计算领域英特尔只是小角色