Sqlserver
 sql >> Base de données >  >> RDS >> Sqlserver

Comment puis-je interroger une valeur dans la colonne SQL Server XML

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