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 シュレッドを複数回参照できます。