XSLT - 检查重复记录中的字段是否包含另一个字段值的有效方法?
XSLT - effective way to check if field in repeating record contains another fields value?
我正在 BizTalk 中处理一个项目,我正在接收 HR 数据,预计在将其路由到目的地之前将其转换为另一种格式。
这是我收到的示例:
<ns0:Employees xmlns:ns0="http://XXX">
<Employee>
<EMPLOYEE_ID>1</EMPLOYEE_ID>
<BOSS_ID>2</BOSS_ID>
</Employee>
<Employee>
<EMPLOYEE_ID>2</EMPLOYEE_ID>
<BOSS_ID>3</BOSS_ID>
</Employee>
<Employee>
<EMPLOYEE_ID>3</EMPLOYEE_ID>
<BOSS_ID>4</BOSS_ID>
</Employee>
<Employee>
<EMPLOYEE_ID>4</EMPLOYEE_ID>
<BOSS_ID>0</BOSS_ID>
</Employee>
</ns0:Employees>
下面是它的外观示例(基于上述来源):
<SyncCXPERSON>
<CXPERSONSet>
<PERSON>
<PERSONID>1</PERSONID>
<SUPERVISOR>2</SUPERVISOR>
<BOSS>false</BOSS>
</PERSON>
<PERSON>
<PERSONID>2</PERSONID>
<SUPERVISOR>3</SUPERVISOR>
<BOSS>true</BOSS>
</PERSON>
<PERSON>
<PERSONID>3</PERSONID>
<SUPERVISOR>4</SUPERVISOR>
<BOSS>true</BOSS>
</PERSON>
<PERSON>
<PERSONID>4</PERSONID>
<SUPERVISOR></SUPERVISOR>
<BOSS>true</BOSS>
</PERSON>
</CXPERSONSet>
</SyncCXPERSON>
如您所见,我必须检查整个重复记录列表 'Employee' 以检查员工是否也是某人的老板,在这种情况下,我将 BOSS 字段设置为 true。这是通过以下 XSLT 完成的:
<xsl:template match="Employees">
<SyncCXPERSON>
<CXPERSONSet>
<xsl:apply-templates select="Employee" />
</CXPERSONSet>
</SyncCXPERSON>
</xsl:template>
<xsl:template match="Employee">
<xsl:variable name="CURRENT_EMPLOYEE_ID" select="EMPLOYEE_ID" />
<PERSON>
<PERSONID>
<xsl:value-of select="$CURRENT_EMPLOYEE_ID"/>
</PERSONID>
<SUPERVISOR>
<xsl:value-of select="BOSS_ID"/>
</SUPERVISOR>
<BOSS>
<xsl:choose>
<xsl:when test="/Employees/Employee/BOSS_ID = $CURRENT_EMPLOYEE_ID">
<xsl:value-of select="true"/>
</xsl:when>
<xsl:otherwise>
<xsl:value-of select="false"/>
</xsl:otherwise>
</xsl:choose>
</BOSS>
</PERSON>
</xsl:template>
这是有效的。问题是,我正在处理大约 35600 个帖子(消息大小为 3 MB),BizTalk 需要大约 2 个小时来处理这个 XSLT。
所以我的问题是:我做错了吗?有更有效的方法吗?
尝试使用 key,例如:
XSLT 1.0
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:key name="emp-by-boss" match="Employee" use="BOSS_ID" />
<xsl:template match="/*">
<SyncCXPERSON>
<CXPERSONSet>
<xsl:apply-templates select="Employee" />
</CXPERSONSet>
</SyncCXPERSON>
</xsl:template>
<xsl:template match="Employee">
<PERSON>
<PERSONID>
<xsl:value-of select="EMPLOYEE_ID"/>
</PERSONID>
<SUPERVISOR>
<xsl:value-of select="BOSS_ID"/>
</SUPERVISOR>
<BOSS>
<xsl:value-of select="boolean(key('emp-by-boss', EMPLOYEE_ID))"/>
</BOSS>
</PERSON>
</xsl:template>
</xsl:stylesheet>
我正在 BizTalk 中处理一个项目,我正在接收 HR 数据,预计在将其路由到目的地之前将其转换为另一种格式。
这是我收到的示例:
<ns0:Employees xmlns:ns0="http://XXX">
<Employee>
<EMPLOYEE_ID>1</EMPLOYEE_ID>
<BOSS_ID>2</BOSS_ID>
</Employee>
<Employee>
<EMPLOYEE_ID>2</EMPLOYEE_ID>
<BOSS_ID>3</BOSS_ID>
</Employee>
<Employee>
<EMPLOYEE_ID>3</EMPLOYEE_ID>
<BOSS_ID>4</BOSS_ID>
</Employee>
<Employee>
<EMPLOYEE_ID>4</EMPLOYEE_ID>
<BOSS_ID>0</BOSS_ID>
</Employee>
</ns0:Employees>
下面是它的外观示例(基于上述来源):
<SyncCXPERSON>
<CXPERSONSet>
<PERSON>
<PERSONID>1</PERSONID>
<SUPERVISOR>2</SUPERVISOR>
<BOSS>false</BOSS>
</PERSON>
<PERSON>
<PERSONID>2</PERSONID>
<SUPERVISOR>3</SUPERVISOR>
<BOSS>true</BOSS>
</PERSON>
<PERSON>
<PERSONID>3</PERSONID>
<SUPERVISOR>4</SUPERVISOR>
<BOSS>true</BOSS>
</PERSON>
<PERSON>
<PERSONID>4</PERSONID>
<SUPERVISOR></SUPERVISOR>
<BOSS>true</BOSS>
</PERSON>
</CXPERSONSet>
</SyncCXPERSON>
如您所见,我必须检查整个重复记录列表 'Employee' 以检查员工是否也是某人的老板,在这种情况下,我将 BOSS 字段设置为 true。这是通过以下 XSLT 完成的:
<xsl:template match="Employees">
<SyncCXPERSON>
<CXPERSONSet>
<xsl:apply-templates select="Employee" />
</CXPERSONSet>
</SyncCXPERSON>
</xsl:template>
<xsl:template match="Employee">
<xsl:variable name="CURRENT_EMPLOYEE_ID" select="EMPLOYEE_ID" />
<PERSON>
<PERSONID>
<xsl:value-of select="$CURRENT_EMPLOYEE_ID"/>
</PERSONID>
<SUPERVISOR>
<xsl:value-of select="BOSS_ID"/>
</SUPERVISOR>
<BOSS>
<xsl:choose>
<xsl:when test="/Employees/Employee/BOSS_ID = $CURRENT_EMPLOYEE_ID">
<xsl:value-of select="true"/>
</xsl:when>
<xsl:otherwise>
<xsl:value-of select="false"/>
</xsl:otherwise>
</xsl:choose>
</BOSS>
</PERSON>
</xsl:template>
这是有效的。问题是,我正在处理大约 35600 个帖子(消息大小为 3 MB),BizTalk 需要大约 2 个小时来处理这个 XSLT。
所以我的问题是:我做错了吗?有更有效的方法吗?
尝试使用 key,例如:
XSLT 1.0
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:key name="emp-by-boss" match="Employee" use="BOSS_ID" />
<xsl:template match="/*">
<SyncCXPERSON>
<CXPERSONSet>
<xsl:apply-templates select="Employee" />
</CXPERSONSet>
</SyncCXPERSON>
</xsl:template>
<xsl:template match="Employee">
<PERSON>
<PERSONID>
<xsl:value-of select="EMPLOYEE_ID"/>
</PERSONID>
<SUPERVISOR>
<xsl:value-of select="BOSS_ID"/>
</SUPERVISOR>
<BOSS>
<xsl:value-of select="boolean(key('emp-by-boss', EMPLOYEE_ID))"/>
</BOSS>
</PERSON>
</xsl:template>
</xsl:stylesheet>