web-dev-qa-db-ja.com

SQL Server XML列の値を照会する方法

SQL ServerデータベースのXML列(Roles)に格納されている次のXMLがあります。

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

特定の役割を持つすべての行をリストしたいのですが。このロールはパラメータによって渡されます。

116
Bistro
select
  Roles
from
  MyTable
where
  Roles.value('(/root/role)[1]', 'varchar(max)') like 'StringToSearchFor'

これらのページでは、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/#!3/ae0d5/13

178
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
34
Mikael Eriksson

フィールド名がRoles、テーブル名がtable1の場合は、以下のように検索できます。

DECLARE @Role varchar(50);
SELECT * FROM table1
WHERE Roles.exist ('/root/role = sql:variable("@Role")') = 1
13
AaA

私は以下に簡単な作業を思い付きました。それも覚えやすいです:-)

select * from  
(select cast (xmlCol as varchar(max)) texty
 from myTable (NOLOCK) 
) a 
where texty like '%MySearchText%'
8
Sagar

あなたは以下をすることができます

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列に対してアドホッククエリを実行する場合は、この手法が非常に便利です。

5
Craig B

便利なチップ。 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
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'
1
ranjit