SQL Server XML 列上的 Where 子句过滤属性 AND 值

Posted

技术标签:

【中文标题】SQL Server XML 列上的 Where 子句过滤属性 AND 值【英文标题】:Where clause on a SQL Server XML column filtering on attribute AND value 【发布时间】:2012-12-20 03:06:26 【问题描述】:

我在“文档”表中有一个“元数据”字段,其中包含以下数据:

<properties>
  <property name="someProp">xyz</property>
  <property name="reportId">55</property>
  <property name="someOtherProp">abc</property>
</properties>'

如何编写一个查询来返回存在名称为“reportId”且“reportId”属性元素的值为 55 的属性元素的记录?有时“reportId”属性节点是唯一存在的,有时不存在,而且它并不总是按上述顺序,所以我无法查询绝对位置。有什么想法吗?

【问题讨论】:

【参考方案1】:

不需要提取值。请改用exist() Method (xml Data Type)。

select *
from Document
where Metadata.exist('/properties/property[@name="reportId" and . = 55]') = 1

【讨论】:

【参考方案2】:

没关系,明白了。供参考:

select * from Document
where Metadata.value('(/properties/property[@name="reportId"])[1]', 'int') = 55

【讨论】:

以上是关于SQL Server XML 列上的 Where 子句过滤属性 AND 值的主要内容,如果未能解决你的问题,请参考以下文章

使用 XPath/XQuery 过滤 XML 列上的 SQL 查询

DateTime 列上的 Mono InvalidOperationException (SQL Server)

SQL Server - 同一列上的多个 PIVOT

为啥 SQL Server 不使用计算列上的索引?

几何列上的 SQL Server 平面世界地图

Sql Server CE - 临时禁用特定列上的自动增量