5

我有一个带有 XML 数据类型列的数据库表。该列包含如下值:

<NameValuePairCollection>
  <NameValuePair Name="Foo" Value="One" />
  <NameValuePair Name="Bar" Value="Two" />
  <NameValuePair Name="Baz" Value="Three" />
</NameValuePairCollection>

我正在尝试查询 XML 数据类型列的值为 for 的所有"One""Foo"。我无法创建适当的 XQuery 来过滤结果。

我发现了几个相关的 SO 问题,这些问题对我的尝试有所帮助,但我仍然无法让它发挥作用。

如何查询 SQL Server XML 列中的值 在 SQL
Server XML 数据类型上使用 LIKE 语句

这是我到目前为止的SQL:

select * 
from MyTable 
where [XmlDataColumn].value('((/NameValuePairCollection/NameValuePair)[@Name="Foo"])[@Value]', 'varchar(max)') = 'One'
order by ID desc 

这是我现在遇到的错误:

XQuery [MyTable.XmlDataColumn.value()]: Cannot atomize/apply data() on expression that contains type 'NameValuePair' within inferred type 'element(NameValuePair,#anonymous) *'

更新(响应@LeoWörteler 的建议)

根据您的回答,我将 SQL 更改为:

select * 
from MyTable with(nolock) 
where [XmlDataColumn].value('/NameValuePairCollection/NameValuePair[@Name="Subject"]/@Value', 'varchar(max)') = 'One'
order by ID desc 

这仍然行不通。我收到以下错误:

XQuery [MyTable.XmlDataColumn.value()]: 'value()' requires a singleton (or empty sequence), found operand of type 'xs:string *'
4

2 回答 2

3

如果您想选择Value属性的值而不是使用 XPath 表达式 in 选择整个NameValuePair元素[XmlDataColumn].value(...),这应该有效:

/NameValuePairCollection/NameValuePair[@Name="Foo"]/@Value

您的表达式仅检查 是否NameValuePair具有属性Value

如果有多个具有正确名称的元素,并且您想检查其中任何一个是否具有 value "One",则可以使用以下exist(...)方法:

where [XmlDataColumn].exist(
  '/NameValuePairCollection/NameValuePair[@Name="Subject" and @Value="One"]') = 1
于 2013-04-10T20:00:54.740 回答
2

另一种选择是将 XML 转换为 varchar,然后搜索给定的字符串,就像 XML vas 是 varchar 字段一样。

SELECT * 
FROM Table
WHERE CAST(Column as nvarchar(max)) LIKE '%Name="Foo" Value="One"%'

我喜欢这个解决方案,因为它干净、易于记忆、不易混淆,并且可以用作 where 子句的一部分。

它不像 Leo 提供的答案那样动态和完整,但根据具体情况,它可能是获取所需数据的“快速和肮脏”的方式。

于 2016-04-14T14:12:47.543 回答