Как я могу запросить значение в столбце XML SQL Server

У меня есть XML, хранящийся в столбце XML (называемый Roles) в базе данных SQL Server.

<root>
   <role>Alpha</role>
   <role>Beta</role>
   <role>Gamma</role>
</root>

Я хотел бы перечислить все строки, которые имеют определенную роль в них. Эта роль передается параметром.

Ответ 1

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

Эти страницы покажут вам больше о том, как запросить XML в T-SQL:

Запрос полей XML с использованием t-sql

Сглаживание XML-данных в 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 Fiddle: http://sqlfiddle.com/#!3/ae0d5/13

Ответ 2

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

Ответ 3

если ваше имя поля - это Роли, а имя таблицы - таблица1, вы можете использовать следующую команду для поиска

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

Ответ 4

Я придумал простую работу, ниже которой легко запомнить: -)

select * from  
(select cast (xmlCol as varchar(max)) texty
 from myTable (NOLOCK) 
) a 
where texty like '%MySearchText%'

Ответ 5

Вы можете сделать следующее

declare @role varchar(100) = 'Alpha'
select * from xmltable where convert(varchar(max),xmlfield) like '%<role>'[email protected]+'</role>%'

Очевидно, это немного хак, и я бы не рекомендовал его для каких-либо формальных решений. Однако я считаю эту технику очень полезной при выполнении adhoc-запросов в столбцах XML в SQL Server Management Studio для SQL Server 2012.

Ответ 6

Я использовал инструкцию ниже для извлечения значений в XML в таблице Sql

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'