我需要从SQL Server导出数据到XML文件。我知道如何输出到一个文本文件,但我有困难的XML格式。
样本数据:
CREATE TABLE dbo.testdata (accountid varchar(100),
activeaccount bit,
text1 varchar(100),
text2 varchar(100))
INSERT INTO dbo.testdata VALUES ('T00000001',0,'Fish' ,'Blue'),
('T00000002',1,'Bread','Red' ),
('T00000003',1,'Onion','Blue')
My XML export code:
SELECT accountid AS '@ID',
activeaccount,
text1,
text2
FROM dbo.testdata
FOR XML PATH ('acccountid'), root ('detail')
导出的输出:
<detail>
<acccountid ID="T00000001">
<activeaccount>0</activeaccount>
<text1>Fish</text1>
<text2>Blue</text2>
</acccountid>
<acccountid ID="T00000002">
<activeaccount>1</activeaccount>
<text1>Bread</text1>
<text2>Red</text2>
</acccountid>
<acccountid ID="T00000003">
<activeaccount>1</activeaccount>
<text1>Onion</text1>
<text2>Blue</text2>
</acccountid>
</detail>
我想要的是"text1"one_answers";text2"字段将缩进到accountid的子类别中,名为"preferences",因此输出如下所示:
<detail>
<acccountid ID="T00000001">
<activeaccount>0</activeaccount>
<preferences>
<text1>Fish</text1>
<text2>Blue</text2>
</preferences>
</acccountid>
<acccountid ID="T00000002">
<activeaccount>1</activeaccount>
<preferences>
<text1>Bread</text1>
<text2>Red</text2>
</preferences>
</acccountid>
<acccountid ID="T00000003">
<activeaccount>1</activeaccount>
<preferences>
<text1>Onion</text1>
<text2>Blue</text2>
</preferences>
</acccountid>
</detail>
这应该是显而易见的,但我在FOR XML PATH命令中尝试的一切都是将字段按错误的顺序放置,根本不起作用或在我不想要的地方添加额外的东西。快把我逼疯了
一种方法是在列的别名中定义它:
SELECT accountid AS '@ID',
activeaccount,
text1 AS [preferences/text1],
text2 AS [preferences/text2]
FROM dbo.testdata
FOR XML PATH ('acccountid'), root ('detail');