0

0

T-SQL的XQuery方法nodes(), value(), query(), exist()怎么用

畫卷琴夢

畫卷琴夢

发布时间:2025-12-31 11:30:10

|

926人浏览过

|

来源于php中文网

原创

nodes()将XML节点路径转为行集但不直接取值,需配合APPLY及value()/query()等方法;value()提取单值且须指定SQL类型;query()返回XML片段;exist()判断节点存在性并返回1/0。

t-sql的xquery方法nodes(), value(), query(), exist()怎么用

nodes() 用来把 XML 拆成行集,不是直接取值

nodes() 的作用是「把 XML 中匹配的节点路径转成虚拟表的一行」,它本身不返回数据,必须配合 APPLY 才能展开。常见错误是以为它能直接提取字符串或数字——其实它只产出 XML 类型的列(通常是 xml 类型的单节点),后续还得用 value()query() 处理。

比如有变量 @x xml = 'applebanana',想拆出每个 元素:

SELECT T.c.query('.') AS order_xml
FROM @x.nodes('/orders/order') AS T(c);

注意三点:

  • /orders/order 是 XPath 表达式,区分大小写,且不能以空格开头
  • T(c) 中的 c 是别名,代表每个匹配到的 节点(仍是 XML 类型)
  • 如果路径没匹配到任何节点,nodes() 返回空结果集(不是 NULL 行)

value() 只能取原子值,且必须指定 SQL 类型

value() 从单个 XML 节点里提取标量值(如 INTVARCHAR(50)),但它有两个硬性要求:一是 XPath 必须返回「恰好一个节点」,二是必须显式声明返回的 SQL 类型,否则报错 XQuery [value()]: 'value()' requires a singleton (or empty sequence)

继续上面的例子,要取出每个订单的 id 属性和 文本内容:

SELECT 
  T.c.value('@id', 'INT') AS order_id,
  T.c.value('item[1]', 'VARCHAR(20)') AS item_name
FROM @x.nodes('/orders/order') AS T(c);

关键细节:

  • @id 表示属性,item[1] 中的 [1] 是必须的——即使只有一个 ,XPath 也得限定为单例
  • 类型写 'VARCHAR(20)' 而不是 varchar,字符串字面量必须加单引号
  • 如果某行的 没有 @idvalue() 返回 NULL,不会报错

query() 返回子 XML 片段,适合嵌套结构重用

query() 把匹配到的节点(或子树)原样返回为 XML 类型,不解析内容。它不要求单例,XPath 可以返回多个节点,比如提取所有 包裹在新根中:

绘蛙AI修图
绘蛙AI修图

绘蛙平台AI修图工具,支持手脚修复、商品重绘、AI扩图、AI换色

下载
SELECT T.c.query('item') AS items
FROM @x.nodes('/orders/order') AS T(c);

输出是两行,每行是类似 apple 的 XML 字符串。常用于:

  • 把一组子节点打包传给另一个存储过程(接收 XML 参数)
  • 生成中间 XML 结构供后续 nodes() 二次拆解
  • 避免手动拼接字符串,保留命名空间和属性

注意:query('.') 返回当前节点自身(含标签),而 value('.', 'NVARCHAR(MAX)') 只取文本内容(不含标签)。

exist() 判断是否存在节点,返回 1/0 而非布尔

exist() 是唯一返回 BIT(即 10)的 XQuery 方法,常用于 WHEREIF 条件。它不关心匹配多少个节点,只要至少一个就返回 1

例如筛选含特定商品的订单:

SELECT *
FROM OrdersTable
WHERE XmlColumn.exist('/order/item[text()="apple"]') = 1;

易错点:

  • 必须跟 = 1= 0 比较,不能直接写 WHERE XmlColumn.exist(...) = TRUE(T-SQL 没布尔字面量)
  • text() 在 XPath 中表示文本节点,"apple" 要加双引号(XPath 规则),不是 SQL 单引号
  • 路径为空或无效时,exist() 返回 NULL,所以条件写成 = 1 更安全(NULL = 1 为 false)

四个方法真正难的不是语法,而是 XPath 表达式的上下文绑定:在 nodes() 后的 value() 里,. 指向的是当前节点,不是原始 XML 根;而 exist() 默认从根开始,除非先用 nodes() 定位过。这点一旦搞混,查半天也不知道为什么取不到值。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

674

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

319

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

345

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1084

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

355

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

672

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

566

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

408

2024.04.29

小游戏4399大全
小游戏4399大全

4399小游戏免费秒玩大全来了!无需下载、即点即玩,涵盖动作、冒险、益智、射击、体育、双人等全品类热门小游戏。经典如《黄金矿工》《森林冰火人》《狂扁小朋友》一应俱全,每日更新最新H5游戏,支持电脑与手机跨端畅玩。访问4399小游戏中心,重温童年回忆,畅享轻松娱乐时光!官方入口安全绿色,无插件、无广告干扰,打开即玩,快乐秒达!

30

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
HTML5/CSS3/JavaScript/ES6入门课程
HTML5/CSS3/JavaScript/ES6入门课程

共102课时 | 6.5万人学习

前端基础到实战(HTML5+CSS3+ES6+NPM)
前端基础到实战(HTML5+CSS3+ES6+NPM)

共162课时 | 18.5万人学习

第二十二期_前端开发
第二十二期_前端开发

共119课时 | 12.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号