首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何根据wso2esb中的数据对xml元素进行排序

如何根据wso2esb中的数据对xml元素进行排序
EN

Stack Overflow用户
提问于 2014-08-23 19:04:46
回答 2查看 283关注 0票数 2

我正在使用wso2esb。我希望使用wso2esb转换数据,我所做的问题是,在响应时,我正在以下行方式获取数据,我将如何安排到升序方式。

代码语言:javascript
复制
<response>
    <customer-details>
        <cusfirstname>Empire Burlesque</cusfirstname>
        <delarname>Bob Dylan</delarname>
        <cusno>254</cusno>
    </customer-details>
    <customer>
        <cusId>6</cusId>
        <customername>Bonnie Tyler</customername>
        <country>UK</country>
        <company>CBS Records</company>
        <price>9.90</price>
        <year>1988</year>
    </customer>
    <customer>
        <cusId>8</cusId>
        <customername>Dolly Parton</customername>
        <country>USA</country>
        <company>RCA</company>
        <price>9.90</price>
        <year>1982</year>
    </customer>
    <customer>
        <cusId>3</cusId>
        <customername>Gary Moore</customername>
        <country>UK</country>
        <company>Virgin records</company>
        <price>10.20</price>
        <year>1990</year>
    </customer>
    <customer>
        <cusId>5</cusId>
        <customername>Eros Ramazzotti</customername>
        <country>EU</country>
        <company>BMG</company>
        <price>9.90</price>
        <year>1997</year>
    </customer>
    <customer>
        <cusId>7</cusId>
        <customername>Bee Gees</customername>
        <country>UK</country>
        <company>Polydor</company>
        <price>10.90</price>
        <year>1998</year>
    </customer>
    <customer>
        <cusId>1</cusId>
        <customername>Dr.Hook</customername>
        <country>UK</country>
        <company>CBS</company>
        <price>8.10</price>
        <year>1973</year>
    </customer>
    <customer>
        <cusId>2</cusId>
        <customername>Rod Stewart</customername>
        <country>UK</country>
        <company>Pickwick</company>
        <price>8.50</price>
        <year>1990</year>
    </customer>
    <customer>
        <cusId>4</cusId>
        <customername>Andrea Bocelli</customername>
        <country>EU</country>
        <company>Polydor</company>
        <price>10.80</price>
        <year>1996</year>
    </customer>
    <customer>
        <cusId>12</cusId>
        <customername>Percy Sledge</customername>
        <country>USA</country>
        <company>Atlantic</company>
        <price>8.70</price>
        <year>1987</year>
    </customer>
    <customer>
        <cusId>9</cusId>
        <customername>Savage Rose</customername>
        <country>EU</country>
        <company>Mega</company>
        <price>10.90</price>
        <year>1995</year>
    </customer>
    <customer>
        <cusId>11</cusId>
        <customername>Many</customername>
        <country>USA</country>
        <company>Grammy</company>
        <price>10.20</price>
        <year>1999</year>
    </customer>
    <customer>
        <cusId>10</cusId>
        <customername>Kenny Rogers</customername>
        <country>UK</country>
        <company>Mucik Master</company>
        <price>8.70</price>
        <year>1995</year>
    </customer>
</response>

我希望基于 cusId 按升序排列客户标记数据,所以我将如何安排它?我尝试了使用xquery,但找不到有关元素排序的任何函数,cusId应该出现在1、2、3、…

我如何实现这一点--我知道xpath中没有函数。

提前谢谢。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-08-23 19:38:08

在XSLT中,当对每个<xsl:sort>使用<xsl:apply-templates>时,您可以使用customer。这个样式表命令客户:

代码语言:javascript
复制
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
    <xsl:output indent="yes"/>
    <xsl:strip-space elements="*"/>

    <xsl:template match="@*|node()">
        <xsl:copy>
            <xsl:apply-templates select="@*|node()"/>
        </xsl:copy>
    </xsl:template>

    <xsl:template match="response">
        <xsl:copy>
            <xsl:apply-templates select="customer-details"/>
            <xsl:apply-templates select="customer">
                <xsl:sort select="cusId"/>
            </xsl:apply-templates>
        </xsl:copy>
    </xsl:template>

</xsl:stylesheet>
票数 3
EN

Stack Overflow用户

发布于 2014-08-23 19:34:15

“我试过使用xquery,但找不到任何有关元素排序的函数”

在XQuery中,使用order by进行排序:

代码语言:javascript
复制
for $i in /response/customer
order by $i/cusId
return $i
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25465434

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档