首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何查询SQL Server XML列中的值

如何查询SQL Server XML列中的值
EN

Stack Overflow用户
提问于 2012-04-27 12:02:04
回答 8查看 480.1K关注 0票数 139

我将以下XML存储在SQL Server数据库的XML列(名为Roles)中。

代码语言:javascript
复制
<root>
   <role>Alpha</role>
   <role>Beta</role>
   <role>Gamma</role>
</root>

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

EN

回答 8

Stack Overflow用户

发布于 2012-04-27 13:42:18

代码语言:javascript
复制
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

如果希望查询以where col like '%Beta%'方式工作,则可以使用contains

代码语言:javascript
复制
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
票数 37
EN

Stack Overflow用户

发布于 2012-04-27 12:05:49

如果您的字段名为Roles,表名为table1,则可以使用以下命令进行搜索

代码语言:javascript
复制
DECLARE @Role varchar(50);
SELECT * FROM table1
WHERE Roles.exist ('/root/role = sql:variable("@Role")') = 1
票数 13
EN

Stack Overflow用户

发布于 2016-10-05 03:12:58

我想出了一个简单的工作,下面也很容易记住:-)

代码语言:javascript
复制
select * from  
(select cast (xmlCol as varchar(max)) texty
 from myTable (NOLOCK) 
) a 
where texty like '%MySearchText%'
票数 8
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10344553

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档