8

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

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

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

4

2 回答 2

10

无需提取值。改用exists() 方法(xml 数据类型)

select *
from Document
where Metadata.exist('/properties/property[@name="reportId" and . = 55]') = 1
于 2013-05-17T13:26:21.507 回答
4

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

select * from Document
where Metadata.value('(/properties/property[@name="reportId"])[1]', 'int') = 55
于 2012-12-20T03:28:07.660 回答