Roles
SQL 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 をクエリする方法について詳しく説明します。
編集
もう少し試してみたところ、次のような素晴らしいクエリができました。クロスアプライ. これは、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