0

SQL Server に、SQL where 句を含む XML 列があります。特定の部分文字列をクエリの結果に置き換えたいと考えています。以下の例では、p.[EconPeriodID] = 4 を EconPeriod = 'Jan 2011' に置き換え、p.[BookID] = 2 を Book = 'Canada' に置き換えます。

<Parameter Name="whereClause" 
           BaseType="nvarchar" 
           Precision="0" 
           Scale="0" 
           MaxLength="64"
          >WHERE (p.[EconomicPeriodID] = 4 and p.[BookID] = 2)</Parameter>

異なるパラメーターを持つ複数のメッセージを返すため、CrossApply 検索を使用していません。

以下の完全なクエリ:

DECLARE @sdt_Date DATETIME
SET @sdt_Date = '3/17/2011'

SELECT  name ,
        submit_time ,
        request,
        CONVERT(VARCHAR, request.value(N'
   (for $A in /ServiceProxy/Event/Parameters/Parameter
   where $A/@Name ="valuationDate"
   return $A/text())[1]
', 'datetime'), 111)
  AS 'EOD Date' ,
        request.query(N'
   for $A in /ServiceProxy/Event/Parameters/Parameter
   where $A/@Name ="whereClause"
   return $A/text()
').value('.', 'varchar(max)') AS 'WHERE Clause' 
FROM    Requests
WHERE   submit_time BETWEEN DATEADD(dd, 0,
                                                      DATEDIFF(dd, 0,
                                                              @sdt_Date))
                                      AND     DATEADD(dd, 1,
                                                      DATEDIFF(dd, 0,
                                                              @sdt_Date))
ORDER BY submit_time DESC

更新: Cross Apply を使用するか、保存されたクエリを変更して人間が読めるパラメーターを使用するかについて議論しています。Cross Apply を使用すると、Replace で使用するために、クエリで XML シュレッドを複数回参照できます。

4

1 に答える 1

0

では、WHERE句を文字列として返しますか?XML列の値を更新しようとしているのではなく、変更された値を返すだけですか?

このようなことをしてもらえますか?

WITH A AS
(  your query minus the ORDER BY clause )
SELECT  Name
     ,  submit_time
     ,  request
     ,  [EOD Date]
     ,  [WHERE Clause] = REPLACE(A.[WHERE Clause], 'p.[EconPeriod] = 4','[EconPeriod] = ''Jan 2011''')
FROM   A
ORDER BY submit_time DESC
于 2011-04-06T21:48:50.153 に答える