sql >> データベース >  >> RDS >> Sqlserver

SQLServerXML列の値をクエリするにはどうすればよいですか

    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



    1. 異なる行で異なる条件を満たす値を選択しますか?

    2. Oracle SQL Developer:REFCURSORの結果をグリッドに表示しますか?

    3. SQL Serverの内部:PlanCachingPt。 I –プランの再利用

    4. SQLで保持率を計算する方法は?