select
Roles
from
MyTable
where
Roles.value('(/root/role)[1]', 'varchar(max)') like 'StringToSearchFor'
Jeśli Twoja kolumna nie jest XML
, musisz to przekonwertować. Możesz również użyć innej składni do zapytania o określone atrybuty danych XML. Oto przykład...
Załóżmy, że kolumna danych ma to:
<Utilities.CodeSystems.CodeSystemCodes iid="107" CodeSystem="2" Code="0001F" CodeTags="-19-"..../>
... i potrzebujesz tylko tych, w których CodeSystem = 2
Twoje zapytanie będzie wyglądało następująco:
select
[data]
from
[dbo].[CodeSystemCodes_data]
where
CAST([data] as XML).value('(/Utilities.CodeSystems.CodeSystemCodes/@CodeSystem)[1]', 'varchar(max)') = '2'
Te strony pokażą Ci więcej o tym, jak odpytywać XML w T-SQL:
Odpytywanie pól XML za pomocą t-sql
Spłaszczanie danych XML w SQL Server
EDYTUJ
Po zabawie z tym trochę więcej, skończyłem z tym niesamowitym zapytaniem, które używa CROSS APPLY. Ten przeszuka każdy wiersz (rolę) pod kątem wartości, którą umieścisz w podobnym wyrażeniu...
Biorąc pod uwagę tę strukturę tabeli:
create table MyTable (Roles XML)
insert into MyTable values
('<root>
<role>Alpha</role>
<role>Gamma</role>
<role>Beta</role>
</root>')
Możemy zapytać o to w ten sposób:
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%'
Możesz sprawdzić SQL Fiddle tutaj:http://sqlfiddle.com/#!18/dc4d2/1/0