SQL Server XML列の値をクエリするにはどうすればよいですか?質問する

SQL Server XML列の値をクエリするにはどうすればよいですか?質問する

RolesSQL Server データベースのXML 列 ( ) に次の XML が保存されています。

<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、変換する必要があります。他の構文を使用して、XML データの特定の属性をクエリすることもできます。次に例を示します...

データ列に次の内容が含まれているとします。

<Utilities.CodeSystems.CodeSystemCodes iid="107" CodeSystem="2" Code="0001F" CodeTags="-19-"..../>

...そして、次のクエリのみが必要な場合、次のようCodeSystem = 2になります。

select 
  [data] 
from
  [dbo].[CodeSystemCodes_data]
  
where
  CAST([data] as XML).value('(/Utilities.CodeSystems.CodeSystemCodes/@CodeSystem)[1]', 'varchar(max)') = '2'

以下のページでは、T-SQL で XML をクエリする方法について詳しく説明します。

t-sql を使用して XML フィールドをクエリする

SQL Server での XML データのフラット化

編集

もう少し試してみたところ、次のような素晴らしいクエリができました。クロスアプライ. これは、like 式に入力した値をすべての行 (ロール) で検索します...

このテーブル構造を考えると、

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/#!18/dc4d2/1/0

おすすめ記事