rag*_*eit 4 xml sql t-sql sql-server-2008-r2
我需要从表中选择一些列作为XML,其中包含名称空间以及其他列.例如,我有以下表格布局:
ID C1 X1C1 X1C2 X2C3
1 A 1 2 3
Run Code Online (Sandbox Code Playgroud)
查询应返回的内容是:
ID C1 XmlData
1 A <xmldata1>
2 A <xmldata2>
Run Code Online (Sandbox Code Playgroud)
哪里<xmldata1>会:
<Root xmlns:xsd="w3.org/2001/XMLSchema" xmlns:xsi="w3.org/2001/XMLSchema-instance" xmlns:mst="microsoft.com/wsdl/types/">
<Child attrib="C1">
<ChildValue xsi:type="xsd:integer">1</ChildNode>
</Child>
<Child attrib="C2">
<ChildNode xsi:type="xsd:integer">2</ChildNode>
</Child>
</Root>
Run Code Online (Sandbox Code Playgroud)
并且<xmldata2>将是:
<Rootxmlns:xsd="w3.org/2001/XMLSchema" xmlns:xsi="w3.org/2001/XMLSchema-instance" xmlns:mst="microsoft.com/wsdl/types/">
<Child attrib="C3">
<ChildNode xsi:type="xsd:integer">3</ChildNode>
</Child>
</Root>
Run Code Online (Sandbox Code Playgroud)
我有一个很好的参考如何从这个SO问题构建xml 但我无法放入名称空间.如果这是可能的怎么办?
编辑:我使用以下查询尝试获得所需的结果:选择1个ID,'A'C1,1个X1C1,2个X1C2,3个X2C3到#t
;with xmlnamespaces('w3.org/2001/XMLSchema' as xsd, 'w3.org/2001/XMLSchema-instance' as xsi, 'microsoft.com/wsdl/types/' as mst)
select ID, C1, (select (SELECT 'C1' "@attrib", 'xsd:integer' "ChildValue/@xsi:type",t.X1C1 as 'ChildValue' FOR XML PATH('Child'), type),(SELECT 'C2' "@name", 'xsd:integer' "ChildValue/@xsi:type", t.X1C2 as 'ChildValue' FOR XML PATH('Child'), type) FOR XML PATH('Root'), type) as property_data
FROM #t t
drop table #t
Run Code Online (Sandbox Code Playgroud)
这是其xml部分的输出:
<Root xmlns:mst="microsoft.com/wsdl/types/" xmlns:xsi="w3.org/2001/XMLSchema-instance" xmlns:xsd="w3.org/2001/XMLSchema">
<Child xmlns:mst="microsoft.com/wsdl/types/" xmlns:xsi="w3.org/2001/XMLSchema-instance" xmlns:xsd="w3.org/2001/XMLSchema" attrib="C1">
<ChildValue xsi:type="xsd:integer">1</ChildValue>
</Child>
<Child xmlns:mst="microsoft.com/wsdl/types/" xmlns:xsi="w3.org/2001/XMLSchema-instance" xmlns:xsd="w3.org/2001/XMLSchema" name="C2">
<ChildValue xsi:type="xsd:integer">2</ChildValue>
</Child>
</Root>
Run Code Online (Sandbox Code Playgroud)
我无法摆脱Child节点中的命名空间.
我使用了这个解决方案:TSQL for xml add schema attribute to root node
基本上,我没有把命名空间放在开头,但是在生成所需的xml结构之后,我将xml转换为nvarchar(max)并用所需的命名空间替换了根节点.
我还需要在属性中使用名称空间前缀.为此,我使用了伪属性名称,我将其替换为正确的xml名称空间前缀.
这两个操作都是使用tsql REPLACE函数完成的.Hacky但是找不到其他正确的方法来做到这一点.