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フィールドのクエリ
SQLServerでのXMLデータのフラット化
編集
もう少し遊んだ後、CROSSAPPLYを使用するこの驚くべきクエリに行き着きました。これは、すべての行(ロール)で、同じような式に入力した値を検索します...
このテーブル構造を考えると:
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フィドルを確認できます:http://sqlfiddle.com/#!18 / dc4d2 / 1/0