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

时间:2012-12-20 03:06:26

标签: sql sql-server xml tsql

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

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

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

2 个答案:

答案 0 :(得分:6)

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

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

答案 1 :(得分:2)

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

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