select
Roles
from
MyTable
where
Roles.value('(/root/role)[1]', 'varchar(max)') like 'StringToSearchFor'
Si votre colonne n'est pas XML
, vous devez le convertir. Vous pouvez également utiliser une autre syntaxe pour interroger certains attributs de vos données XML. Voici un exemple...
Supposons que cette colonne de données ait ceci :
<Utilities.CodeSystems.CodeSystemCodes iid="107" CodeSystem="2" Code="0001F" CodeTags="-19-"..../>
... et vous ne voulez que ceux où CodeSystem = 2
alors votre requête sera :
select
[data]
from
[dbo].[CodeSystemCodes_data]
where
CAST([data] as XML).value('(/Utilities.CodeSystems.CodeSystemCodes/@CodeSystem)[1]', 'varchar(max)') = '2'
Ces pages vous montreront comment interroger XML dans T-SQL :
Interroger des champs XML à l'aide de t-sql
Aplatir les données XML dans SQL Server
MODIFIER
Après avoir joué un peu plus avec, je me suis retrouvé avec cette requête étonnante qui utilise CROSS APPLY. Celui-ci recherchera dans chaque ligne (rôle) la valeur que vous avez mise dans votre expression similaire...
Étant donné cette structure de table :
create table MyTable (Roles XML)
insert into MyTable values
('<root>
<role>Alpha</role>
<role>Gamma</role>
<role>Beta</role>
</root>')
Nous pouvons l'interroger comme ceci :
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%'
Vous pouvez vérifier le SQL Fiddle ici :http://sqlfiddle.com/#!18/dc4d2/1/0