微软BI 之SSIS 系列 - XML Task 中XSLT 样式表转换错误记录
2014-09-27 16:43 BIWORK 阅读(1028) 评论(0) 编辑 收藏 举报开篇介绍
此文章专门记录 XSLT 样式表转换过程中的语法问题
错误一 值与属性的倒置
修改了几次样式表,但还是一如既往的报错,报错信息如下:
[XML Task] Error: An error occurred with the following error message: "Attribute and namespace nodes cannot be added to the parent element after a text, comment, pi, or sub-element node has already been added.".
很明显 XML Task 已经告知了错误的原因,即属性或者命名空间的定义不能跟随已经存在的文之后。
正确的写法:
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" indent="yes"/>
<xsl:template match="/">
<newsalesorder>
<xsl:for-each select="SalesOrder/SalesOrderDetail">
<salesorderdetail>
<salesorderID>
<xsl:attribute name="detailID">
<xsl:value-of select="SalesOrderDetailID"/>
</xsl:attribute>
<xsl:value-of select="SalesOrderID"/>
</salesorderID>
</salesorderdetail>
</xsl:for-each>
</newsalesorder>
</xsl:template>
</xsl:stylesheet>
错误的写法 - SalesOrderID 在 XML Task 转换时,源 SalesOrderID 的值一经写出,后面再跟 Attribute 是不正确的,应该是 Attribute 在前。
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" indent="yes"/>
<xsl:template match="/">
<newsalesorder>
<xsl:for-each select="SalesOrder/SalesOrderDetail">
<salesorderdetail>
<salesorderID>
<xsl:value-of select="SalesOrderID"/>
<xsl:attribute name="detailID">
<xsl:value-of select="SalesOrderDetailID"/>
</xsl:attribute>
</salesorderID>
</salesorderdetail>
</xsl:for-each>
</newsalesorder>
</xsl:template>
</xsl:stylesheet>
正确的输出片段中 detailID 这个 Attribute 属性应该要定义在 SalesOrderID 71774 之前。
<?xml version="1.0" encoding="utf-8"?>
<newsalesorder>
<salesorderdetail>
<salesorderID detailID="110562">71774</salesorderID>
</salesorderdetail>
<salesorderdetail>
<salesorderID detailID="110563">71774</salesorderID>
</salesorderdetail>
<salesorderdetail>
<salesorderID detailID="110567">71776</salesorderID>
</salesorderdetail>
相关资源
更多 BI 文章请参看 BI 系列随笔列表 (SSIS, SSRS, SSAS, MDX, SQL Server) 如果觉得这篇文章看了对您有帮助,请帮助推荐,以方便他人在 BIWORK 博客推荐栏中快速看到这些文章。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 单线程的Redis速度为什么快?
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 展开说说关于C#中ORM框架的用法!
· SQL Server 2025 AI相关能力初探
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库