如何查询SQL Server XML列中的值

Bis*_*tro 122 xml sql sql-server xquery

我跟踪存储在RolesSQL Server数据库中的XML列(称为)中的XML .

<root>
   <role>Alpha</role>
   <role>Beta</role>
   <role>Gamma</role>
</root>
Run Code Online (Sandbox Code Playgroud)

我想列出在其中具有特定角色的所有行.此角色由参数传递.

Len*_*rri 191

select
  Roles
from
  MyTable
where
  Roles.value('(/root/role)[1]', 'varchar(max)') like 'StringToSearchFor'
Run Code Online (Sandbox Code Playgroud)

这些页面将向您展示如何在T-SQL中查询XML的更多信息:

使用t-sql查询XML字段

在SQL Server中展平XML数据

编辑

在玩了一点之后,我最终得到了这个使用CROSS APPLY的惊人查询.这个将搜索你在你喜欢的表达式中放置的值的每一行(角色)......

鉴于此表结构:

create table MyTable (Roles XML)

insert into MyTable values
('<root>
   <role>Alpha</role>
   <role>Gamma</role>
   <role>Beta</role>
</root>')
Run Code Online (Sandbox Code Playgroud)

我们可以这样查询:

select * from 

(select 
       pref.value('(text())[1]', 'varchar(32)') as RoleName
from 
       MyTable CROSS APPLY

       Roles.nodes('/root/role') AS Roles(pref)
)  as Result

where RoleName like '%ga%'
Run Code Online (Sandbox Code Playgroud)

你可以在这里检查SQL小提琴:http://sqlfiddle.com/#!3/ae0d5/13

  • @Bistro询问`[1]`是一个非常好的问题.这意味着您从XML中选择第一个角色值,这意味着这仅适用于在示例xml中查找"Alpha".如果您搜索"Beta",它将找不到该行. (6认同)
  • 它回答了我的所有问题,你的答案中有什么`[1]`做什么? (5认同)

Mik*_*son 34

declare @T table(Roles xml)

insert into @T values
('<root>
   <role>Alpha</role>
   <role>Beta</role>
   <role>Gamma</role>
</root>')

declare @Role varchar(10)

set @Role = 'Beta'

select Roles
from @T
where Roles.exist('/root/role/text()[. = sql:variable("@Role")]') = 1
Run Code Online (Sandbox Code Playgroud)

如果您希望查询能够正常where col like '%Beta%'使用contains

declare @T table(Roles xml)

insert into @T values
('<root>
   <role>Alpha</role>
   <role>Beta</role>
   <role>Gamma</role>
</root>')

declare @Role varchar(10)

set @Role = 'et'

select Roles
from @T
where Roles.exist('/root/role/text()[contains(., sql:variable("@Role"))]') = 1
Run Code Online (Sandbox Code Playgroud)


AaA*_*AaA 13

如果您的字段名称是角色,而表名称是table1,您可以使用以下搜索

DECLARE @Role varchar(50);
SELECT * FROM table1
WHERE Roles.exist ('/root/role = sql:variable("@Role")') = 1
Run Code Online (Sandbox Code Playgroud)

  • 你试过这个吗?无论你在`@ Role`中放什么,它都能找到所有东西. (4认同)
  • 使用`.value('(/ root/role)[1]','varchar(max)')像'%yourtext%'`而不是`exists`,Leniel解释 (2认同)

Sag*_*gar 7

我想出了一个简单易懂的简单工作:-)

select * from  
(select cast (xmlCol as varchar(max)) texty
 from myTable (NOLOCK) 
) a 
where texty like '%MySearchText%'
Run Code Online (Sandbox Code Playgroud)


小智 5

您可以执行以下操作

declare @role varchar(100) = 'Alpha'
select * from xmltable where convert(varchar(max),xmlfield) like '%<role>'+@role+'</role>%'
Run Code Online (Sandbox Code Playgroud)

显然,这有点麻烦,我不建议在任何正式的解决方案中使用它。但是,我发现在针对SQL Server 2012的SQL Server Management Studio中对XML列进行临时查询时,此技术非常有用。