140

RolesSQL Server データベースの XML 列 ( と呼ばれる) に次の XML が格納されています。

<root>
   <role>Alpha</role>
   <role>Beta</role>
   <role>Gamma</role>
</root>

特定の役割を持つすべての行を一覧表示したいと思います。このロールはパラメーターで渡されます。

4

9 に答える 9

218
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 データのフラット化

編集

もう少し遊んだ後、CROSS APPLYを使用するこの驚くべきクエリにたどり着きました。これは、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

于 2012-04-27T04:09:43.577 に答える
37
declare @T table(Roles xml)

insert into @T values
('<root>
   <role>Alpha</role>
   <role>Beta</role>
   <role>Gamma</role>
</root>')

declare @Role varchar(10)

set @Role = 'Beta'

select Roles
from @T
where Roles.exist('/root/role/text()[. = sql:variable("@Role")]') = 1

where col like '%Beta%'使用できるようにクエリを機能させたい場合contains

declare @T table(Roles xml)

insert into @T values
('<root>
   <role>Alpha</role>
   <role>Beta</role>
   <role>Gamma</role>
</root>')

declare @Role varchar(10)

set @Role = 'et'

select Roles
from @T
where Roles.exist('/root/role/text()[contains(., sql:variable("@Role"))]') = 1
于 2012-04-27T05:42:18.137 に答える
13

フィールド名がRolesで、テーブル名がtable1の場合、以下を使用して検索できます

DECLARE @Role varchar(50);
SELECT * FROM table1
WHERE Roles.exist ('/root/role = sql:variable("@Role")') = 1
于 2012-04-27T04:05:49.243 に答える
6

次のことができます

declare @role varchar(100) = 'Alpha'
select * from xmltable where convert(varchar(max),xmlfield) like '%<role>'+@role+'</role>%'

明らかにこれはちょっとしたハックであり、正式なソリューションにはお勧めしません。ただし、この手法は、SQL Server 2012 の SQL Server Management Studio で XML 列に対してアドホック クエリを実行する場合に非常に便利です。

于 2015-09-08T23:06:54.053 に答える
2

役立つヒント。SQL Server XML 列 (名前空間を含む XML) の値を照会する

例えば

Table [dbo].[Log_XML] contains columns Parametrs (xml),TimeEdit (datetime)

例: パラメータ内の XML:

<ns0:Record xmlns:ns0="http://Integration"> 
<MATERIAL>10</MATERIAL> 
<BATCH>A1</BATCH> 
</ns0:Record>

例: クエリ:

select
 Parametrs,TimeEdit
from
 [dbo].[Log_XML]
where
 Parametrs.value('(//*:Record/BATCH)[1]', 'varchar(max)') like '%A1%'
 ORDER BY TimeEdit DESC
于 2018-09-18T15:29:08.753 に答える
1

以下のステートメントを使用して、SQL テーブルの XML の値を取得しました

with xmlnamespaces(default 'http://test.com/2008/06/23/HL.OnlineContract.ValueObjects')
select * from (
select
            OnlineContractID,
            DistributorID,
            SponsorID,
    [RequestXML].value(N'/OnlineContractDS[1]/Properties[1]/Name[1]', 'nvarchar(30)') as [Name]
   ,[RequestXML].value(N'/OnlineContractDS[1]/Properties[1]/Value[1]', 'nvarchar(30)') as [Value]
     ,[RequestXML].value(N'/OnlineContractDS[1]/Locale[1]', 'nvarchar(30)') as [Locale]
from [OnlineContract]) as olc
where olc.Name like '%EMAIL%' and olc.Value like '%EMAIL%' and olc.Locale='UK EN'
于 2014-03-07T11:44:49.480 に答える