2014-10-27 81 views
0

我正尝试按两个字段之一排序XML节点集,条件是另一个字段中的值。按两个字段中的一个进行排序

<xsl:for-each select="CampusCourseDeliveryItem"> 
    <xsl:sort select="OffCampus"/> 
    <xsl:sort select="OrganisationName" /> 
    <xsl:sort select="OffCampusLocation"/> 

<!-- code to display node goes here --> 

我想,如果OffCampus='Y',使用OffCampusLocation作为排序关键字,否则使用OrganisationName

示例数据:

<CampusCourseDelivery> 
    <CampusCourseDeliveryItem> 
     <OrganisationName>Chicago</OrganisationName> 
     <OffCampus>N</OffCampus> 
     <OffCampusLocation></OffCampusLocation> 
    </CampusCourseDeliveryItem> 
    <CampusCourseDeliveryItem> 
     <OrganisationName>London</OrganisationName> 
     <OffCampus>Y</OffCampus> 
     <OffCampusLocation>Detroit</OffCampusLocation> 
    </CampusCourseDeliveryItem> 
    <CampusCourseDeliveryItem> 
     <OrganisationName>Seattle</OrganisationName> 
     <OffCampus>Y</OffCampus> 
     <OffCampusLocation>Berlin</OffCampusLocation> 
    </CampusCourseDeliveryItem> 
    <CampusCourseDeliveryItem> 
     <OrganisationName>Adelaide</OrganisationName> 
     <OffCampus>N</OffCampus> 
     <OffCampusLocation>Ignore this value</OffCampusLocation> 
    </CampusCourseDeliveryItem> 
</CampusCourseDelivery> 

预期排序顺序:

Adelaide 
Berlin 
Chicago 
Detroit 

回答

3

排序由下式:

concat(
substring(OffCampusLocation, 1, string-length(OffCampusLocation) * (OffCampus='Y')), 
substring(OrganisationName, 1, string-length(OrganisationName) * (OffCampus='N'))  
) 
+0

这几乎是* *工作...我不得不改变' OffCampus ='N''到'normalize-space(OffCampus)!='Y''来处理OffCampus为空的情况。 (在我的示例数据中,我没有举一个例子,所以你没有照顾它。) – Adeptus 2014-10-27 01:37:05

相关问题