我有一个xml,它可能会也可能不会产生多个系统编号。如果系统编号和外部 ID 相同,则它应仅保留一个值。
输入:
<?xml version = '1.0' encoding = 'UTF-8'?>
<ns0:updatePersonCrossReference_Input xmlns:ns0="http://xmlns.oracle.com/apps/mdm/customer">
<xsdLocal3:ListOfSwiPersonPublishIO xmlns:xsdLocal3="http://www.siebel.com/xml/SwiPersonPublishIO">
<xsdLocal3:Contact>
<xsdLocal3:IntegrationId>0100004568</xsdLocal3:IntegrationId>
<xsdLocal3:ListOfCIFContactReference>
<xsdLocal3:CIFContactReference>
<xsdLocal3:SystemNumber>GCIS</xsdLocal3:SystemNumber>
<xsdLocal3:SystemName>GCIS</xsdLocal3:SystemName>
<xsdLocal3:ExternalId>1016</xsdLocal3:ExternalId>
</xsdLocal3:CIFContactReference>
<xsdLocal3:CIFContactReference>
<xsdLocal3:SystemNumber>GCIS</xsdLocal3:SystemNumber>
<xsdLocal3:SystemName>GCIS</xsdLocal3:SystemName>
<xsdLocal3:ExternalId>1016</xsdLocal3:ExternalId>
</xsdLocal3:CIFContactReference>
<xsdLocal3:CIFContactReference>
<xsdLocal3:SystemNumber>HOG</xsdLocal3:SystemNumber>
<xsdLocal3:SystemName>HOG</xsdLocal3:SystemName>
<xsdLocal3:ExternalId>2002</xsdLocal3:ExternalId>
</xsdLocal3:CIFContactReference>
<xsdLocal3:CIFContactReference>
<xsdLocal3:SystemNumber>HOG</xsdLocal3:SystemNumber>
<xsdLocal3:SystemName>HOG</xsdLocal3:SystemName>
<xsdLocal3:ExternalId>2002</xsdLocal3:ExternalId>
</xsdLocal3:CIFContactReference>
<xsdLocal3:CIFContactReference>
<xsdLocal3:SystemNumber>OCR</xsdLocal3:SystemNumber>
<xsdLocal3:SystemName>OCR</xsdLocal3:SystemName>
<xsdLocal3:ExternalId>3003</xsdLocal3:ExternalId>
</xsdLocal3:CIFContactReference>
<xsdLocal3:CIFContactReference>
<xsdLocal3:SystemNumber>OCR</xsdLocal3:SystemNumber>
<xsdLocal3:SystemName>OCR</xsdLocal3:SystemName>
<xsdLocal3:ExternalId>3003</xsdLocal3:ExternalId>
</xsdLocal3:CIFContactReference>
</xsdLocal3:ListOfCIFContactReference>
</xsdLocal3:Contact>
</xsdLocal3:ListOfSwiPersonPublishIO>
</ns0:updatePersonCrossReference_Input>
输出应为:
<?xml version = '1.0' encoding = 'UTF-8'?>
<ns0:updatePersonCrossReference_Input xmlns:ns0="http://xmlns.oracle.com/apps/mdm/customer">
<xsdLocal3:ListOfSwiPersonPublishIO xmlns:xsdLocal3="http://www.siebel.com/xml/SwiPersonPublishIO">
<xsdLocal3:Contact>
<xsdLocal3:IntegrationId>0100004568</xsdLocal3:IntegrationId>
<xsdLocal3:ListOfCIFContactReference>
<xsdLocal3:CIFContactReference>
<xsdLocal3:SystemNumber>GCIS</xsdLocal3:SystemNumber>
<xsdLocal3:SystemName>GCIS</xsdLocal3:SystemName>
<xsdLocal3:ExternalId>1016</xsdLocal3:ExternalId>
</xsdLocal3:CIFContactReference>
<xsdLocal3:CIFContactReference>
<xsdLocal3:SystemNumber>HOG</xsdLocal3:SystemNumber>
<xsdLocal3:SystemName>HOG</xsdLocal3:SystemName>
<xsdLocal3:ExternalId>2002</xsdLocal3:ExternalId>
</xsdLocal3:CIFContactReference>
<xsdLocal3:CIFContactReference>
<xsdLocal3:SystemNumber>OCR</xsdLocal3:SystemNumber>
<xsdLocal3:SystemName>OCR</xsdLocal3:SystemName>
<xsdLocal3:ExternalId>3003</xsdLocal3:ExternalId>
</xsdLocal3:CIFContactReference>
</xsdLocal3:ListOfCIFContactReference>
</xsdLocal3:Contact>
</xsdLocal3:ListOfSwiPersonPublishIO>
</ns0:updatePersonCrossReference_Input>
如果输入为 :
<?xml version = '1.0' encoding = 'UTF-8'?>
<ns0:updatePersonCrossReference_Input xmlns:ns0="http://xmlns.oracle.com/apps/mdm/customer">
<xsdLocal3:ListOfSwiPersonPublishIO xmlns:xsdLocal3="http://www.siebel.com/xml/SwiPersonPublishIO">
<xsdLocal3:Contact>
<xsdLocal3:IntegrationId>0100004568</xsdLocal3:IntegrationId>
<xsdLocal3:ListOfCIFContactReference>
<xsdLocal3:CIFContactReference>
<xsdLocal3:SystemNumber>GCIS</xsdLocal3:SystemNumber>
<xsdLocal3:SystemName>GCIS</xsdLocal3:SystemName>
<xsdLocal3:ExternalId>1016</xsdLocal3:ExternalId>
</xsdLocal3:CIFContactReference>
<xsdLocal3:CIFContactReference>
<xsdLocal3:SystemNumber>HOG</xsdLocal3:SystemNumber>
<xsdLocal3:SystemName>HOG</xsdLocal3:SystemName>
<xsdLocal3:ExternalId>2002</xsdLocal3:ExternalId>
</xsdLocal3:CIFContactReference>
<xsdLocal3:CIFContactReference>
<xsdLocal3:SystemNumber>OCR</xsdLocal3:SystemNumber>
<xsdLocal3:SystemName>OCR</xsdLocal3:SystemName>
<xsdLocal3:ExternalId>3003</xsdLocal3:ExternalId>
</xsdLocal3:CIFContactReference>
</xsdLocal3:ListOfCIFContactReference>
</xsdLocal3:Contact>
</xsdLocal3:ListOfSwiPersonPublishIO>
</ns0:updatePersonCrossReference_Input>
然后输出应显示相同。
任何投入都值得赞赏。我正在使用 XSL 1.0。
谢谢米·
Muenchian grouping,即
(只是在没有语法检查的情况下输入,但应该像这样。
- 为 CIFContactReference 创建一个复合索引,就像
(我曾经添加一个外来字符,比如"_",用于分隔键,当 no. 和 id 是可变长度并且合并可能会重复时。
- 然后在 xsdLocal3:ListOfCIFContactReference 中进行清理,
检查具有相同键的第一个节点(即.key('ref',$keyValue)[1])是否与实际节点具有相同的ID(那么这是列表中的第一个)。
在大多数情况下,这比以下兄弟姐妹快得多::xsdLocal3:CIFContactReference[...])检查;但是,如果您的列表仅由 1-2 个元素组成,则以下同级元素可能会更快一些。