FORXMLクエリの結果をテキストとして取得しようとしています。私はここでいくつかの同様の質問を見つけました: SQL Server "FOR XML"の使用:結果のデータ型をText / varchar / stringに変換しますか? しかし、私の場合、WITH XMLNAMESPACESステートメントを使用していますが、このソリューションは機能しません。この次のクエリの結果をテキストとして取得するにはどうすればよいですか?
WITH XMLNAMESPACES ('urn:blablablabla' as bi)
SELECT 'urn:blablabla.xsd' AS "@xsi:schemaLocation",
(SELECT 'aaaa' AS 'bi:idValue',
'bbbb' AS 'bi:idContext'
FOR XML PATH('bi:Part1'),TYPE),
(SELECT 'cccc' AS 'bi:idValue',
'dddd' AS 'bi:idContext'
FOR XML PATH('bi:Part2'),TYPE)
FOR XML PATH('bi:Items'), ELEMENTS XSINIL
ありがとう
結果は次のようになります。
<bi:Items xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:bi="urn:blablablabla" xsi:schemaLocation="urn:blablabla.xsd">
<bi:Part1 xmlns:bi="urn:blablablabla">
<bi:idValue>aaaa</bi:idValue>
<bi:idContext>bbbb</bi:idContext>
</bi:Part1>
<bi:Part2 xmlns:bi="urn:blablablabla">
<bi:idValue>cccc</bi:idValue>
<bi:idContext>dddd</bi:idContext>
</bi:Part2>
</bi:Items
私の目標は、この結果をXMLデータ型ではなくテキストとして取得することです。たとえば、次のようなことを行います。
DECLARE @ResultText NVARCHAR(MAX)
SET @ResultText = ... Returned text from this query ...
さらに、各ノードで名前空間の繰り返しを回避する方法を知っているかもしれません。
ありがとうございました