我已将XML存储在SQL Server数据库的XML列(名为Roles
)中。
<root>
<role>Alpha</role>
<role>Beta</role>
<role>Gamma</role>
</root>
我想列出所有具有特定角色的行。此角色由参数传递。
答案 0 :(得分:178)
select
Roles
from
MyTable
where
Roles.value('(/root/role)[1]', 'varchar(max)') like 'StringToSearchFor'
这些页面将向您展示如何在T-SQL中查询XML:
Querying XML fields using t-sql
Flattening XML Data in SQL Server
修改强>
在玩了一点之后,我最终得到了这个使用CROSS APPLY的惊人查询。这个将搜索你在你喜欢的表达式中放置的值的每一行(角色)......
鉴于此表结构:
create table MyTable (Roles XML)
insert into MyTable values
('<root>
<role>Alpha</role>
<role>Gamma</role>
<role>Beta</role>
</root>')
我们可以像这样查询:
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%'
您可以在此处查看SQL小提琴:http://sqlfiddle.com/#!3/ae0d5/13
答案 1 :(得分: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
如果您希望查询以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
答案 2 :(得分:13)
如果您的字段名称是角色,而表名是table1,您可以使用以下搜索
DECLARE @Role varchar(50);
SELECT * FROM table1
WHERE Roles.exist ('/root/role = sql:variable("@Role")') = 1
答案 3 :(得分:8)
我想出了一个简单易懂的简单工作: - )
select * from
(select cast (xmlCol as varchar(max)) texty
from myTable (NOLOCK)
) a
where texty like '%MySearchText%'
答案 4 :(得分:5)
您可以执行以下操作
declare @role varchar(100) = 'Alpha'
select * from xmltable where convert(varchar(max),xmlfield) like '%<role>'+@role+'</role>%'
显然这是一个黑客攻击,我不建议任何正式的解决方案。但是,我发现这种技术在SQL Server Management Studio for SQL Server 2012中对XML列进行adhoc查询时非常有用。
答案 5 :(得分:1)
我使用下面的语句来检索Sql表中的XML中的值
with xmlnamespaces(default 'http://test.com/2008/06/23/HL.OnlineContract.ValueObjects')
select * from (
select
OnlineContractID,
DistributorID,
SponsorID,
[RequestXML].value(N'/OnlineContractDS[1]/Properties[1]/Name[1]', 'nvarchar(30)') as [Name]
,[RequestXML].value(N'/OnlineContractDS[1]/Properties[1]/Value[1]', 'nvarchar(30)') as [Value]
,[RequestXML].value(N'/OnlineContractDS[1]/Locale[1]', 'nvarchar(30)') as [Locale]
from [OnlineContract]) as olc
where olc.Name like '%EMAIL%' and olc.Value like '%EMAIL%' and olc.Locale='UK EN'
答案 6 :(得分:1)
有用的提示。在SQL Server XML列(带有命名空间的XML)中查询值
例如
Table [dbo].[Log_XML] contains columns Parametrs (xml),TimeEdit (datetime)
例如参数中的XML:
<ns0:Record xmlns:ns0="http://Integration">
<MATERIAL>10</MATERIAL>
<BATCH>A1</BATCH>
</ns0:Record>
例如查询:
select
Parametrs,TimeEdit
from
[dbo].[Log_XML]
where
Parametrs.value('(//*:Record/BATCH)[1]', 'varchar(max)') like '%A1%'
ORDER BY TimeEdit DESC
答案 7 :(得分:0)
您可以查询整个标签,也可以查询特定值。在这里,我对xml名称空间使用通配符。
declare @myDoc xml
set @myDoc =
'<Root xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://stackoverflow.com">
<Child>my value</Child>
</Root>'
select @myDoc.query('/*:Root/*:Child') -- whole tag
select @myDoc.value('(/*:Root/*:Child)[1]', 'varchar(255)') -- only value
答案 8 :(得分:0)
如果要查找除“ Alpha”之外的其他节点,查询应该是这样的:
y