我有一个 XSLT 转换,它将节点 NADR_KOD 的名称更改为 NADR_KOD2,并复制 XML 的其余部分而不做任何更改。今天我想添加另一个将属性更改为元素的转换(我在堆栈上找到了解决方案)但是一个 xslt 中的这两个转换不起作用......
出现问题是因为我无法在 SSIS 中加载“日期”属性。XML Source 始终将日期返回为空。也许你可以帮我解决这个问题?
XML的结构:
<DATA>
<ACCIDENT date="...">
<INFO>
<TEMP>
<NADR_KOD>
<NADR_KOD>Code</NADR_KOD>
</NADR_KOD>
</TEMP>
</INFO>
</ACCIDENT>
</DATA>
这是我想要的:
<DATA>
<ACCIDENT>
<date>...</date>
<INFO>
<TEMP>
<NADR_KOD>
<NADR_KOD2>Code</NADR_KOD2>
</NADR_KOD>
</TEMP>
</INFO>
</ACCIDENT>
</DATA>
我有几个类似的转换。这是我做这个的方法:
<xsl:template match="ACCIDENT">
<!-- output a filter element -->
<xsl:element name="ACCIDENT">
<!-- add the name attribute, using the source name attribute value -->
<xsl:element name="date">
<xsl:value-of select="@date"/>
</xsl:element>
<!-- add the rest of attributes without change -->
<xsl:copy-of select="node()"/>
</xsl:element>
</xsl:template>
<xsl:template match="NADR_KOD/NADR_KOD">
<NADR_KOD2>
<xsl:apply-templates select="@*|node()"/>
</NADR_KOD2>
</xsl:template>
此代码不会将 NADR_KOD 更改为 NADR_KOD2。提前致谢...