SQL Server WITH XMLNAMESPACES动态声明

时间:2011-06-02 11:22:16

标签: sql sql-server xml

我有以下查询:

;WITH XMLNAMESPACES (
    'Bob' AS b
)
SELECT 'Test' AS [@b:Test]
FOR XML PATH('root')

但是,我希望在运行时从配置表中动态选取名称空间定义。我尝试了以下内容,但它们似乎不是有效的SQL:

-- use a sub query
;WITH XMLNAMESPACES (
    (SELECT 'Fred') AS b
)
SELECT 'Test' AS [@b:Test]
FOR XML PATH('root')

-- declare a variable
DECLARE @ns VARCHAR(10) = 'Fred'

;WITH XMLNAMESPACES (
    @ns AS b
)
SELECT 'Test' AS [@b:Test]
FOR XML PATH('root')

有没有办法让名称空间定义动态化?

谢谢,
汤姆

2 个答案:

答案 0 :(得分:1)

您应该使用动态SQL:

DECLARE @d NVARCHAR(30)='Fred'

;WITH XMLNAMESPACES (
    'UniqueValue' AS b
)
SELECT @ns=(
SELECT  'Test' AS [@b:Test]
FOR XML PATH('root'))

SELECT CAST(REPLACE(@ns, 'UniqueValue',@D) AS XML)

答案 1 :(得分:0)

我实际上已经切换到使用FOR XML EXPLICIT模式来控制输出 - http://msdn.microsoft.com/en-us/library/ms189068(v=SQL.100).aspx - 因为我使用嵌套的XML片段并获取空的xmlns属性。这也允许我动态设置命名空间,而不需要占位符和字符串操作。