我在用着FOR XML PATH
从 SQL Server 2008R2 中的表构造 XML。 XML 必须按如下方式构建:
<Root>
<OuterElement>
<NumberNode>1</NumberNode>
<FormattedNumberNode>0001</KFormattedNumberNode>
<InnerContainerElement>
<InnerNodeOne>0240</InnerNodeOne>
<InnerNodeStartDate>201201</InnerNodeStartDate>
</InnerContainerElement>
</OuterElement>
</Root>
根据架构文件,InnerContainerElement
是可选的,而InnerNodeOne
是必须的。模式文件不是我设置的,非常复杂,相互引用并且没有显式的 XSD 命名空间,因此我无法轻松地将它们加载到数据库中。
必须从表创建 XML,该表使用以下查询填充:
SELECT
1 AS NumberNode
, '0001' AS [FormattedNumberNode]
, '0240' AS [InnerNodeOne]
, '201201' AS [InnerNodeStartDate]
INTO #temporaryXMLStore
UNION
SELECT
2 AS NumberNode
, '0001' AS [FormattedNumberNode]
, NULL AS [InnerNodeOne]
, NULL AS [InnerNodeStartDate]
我可以想到两种构建此 XML 的方法FOR XML PATH
.
1) 使用“InnerContainerElement”作为 XML 子查询的命名结果:
SELECT
NumberNode
, [FormattedNumberNode]
, (
SELECT
[InnerNodeOne]
, [InnerNodeStartDate]
FOR XML PATH(''), TYPE
) AS [InnerContainerElement]
FROM #temporaryXMLStore
FOR XML PATH('OuterElement'), ROOT('Root') TYPE
2) 使用“InnerContainerElement”作为 XML 子查询的输出元素,但不命名它:
SELECT
NumberNode
, [FormattedNumberNode]
, (
SELECT
[InnerNodeOne]
, [InnerNodeStartDate]
FOR XML PATH('InnerContainerElement'), TYPE
)
FROM #temporaryXMLStore
FOR XML PATH('OuterElement'), ROOT('Root'), TYPE
然而,它们都没有给出期望的结果:在这两种情况下,结果看起来像
<Root>
<OuterElement>
<NumberNode>1</NumberNode>
<FormattedNumberNode>0001</FormattedNumberNode>
<InnerContainerElement>
<InnerNodeOne>0240</InnerNodeOne>
<InnerNodeStartDate>201201</InnerNodeStartDate>
</InnerContainerElement>
</OuterElement>
<OuterElement>
<NumberNode>2</NumberNode>
<FormattedNumberNode>0001</FormattedNumberNode>
<InnerContainerElement></InnerContainerElement>
<!-- Or, when using the second codeblock: <InnerContainerElement /> -->
</OuterElement>
</Root>
每当InnerContainerElement
为空,仍然显示为空元素。根据架构,这是无效的:每当元素InnerContainerElement
在 XML 中,InnerNodeOne
是必需的,以。
我如何构建我的FOR XML PATH
以这样的方式查询InnerContainerElement
每当它为空时就会被遗漏吗?