在XSLT转换中获得第一个孩子

时间:2013-04-09 17:03:47

标签: xslt

我有以下XSL,我用它将Oracle SQL开发人员的XML格式转换为" full" DBUnit期望的XML格式(用于创建用于测试的数据集)。

<?xml version="1.0"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:java="java"
    xmlns:dbutil="com.jason.util.DatabaseTestUtil">
    <xsl:output method="xml" indent="yes" />
    <xsl:template match="/">
        <xsl:text disable-output-escaping="yes">&lt;dataset&gt;</xsl:text>
        <xsl:text>&#xa;</xsl:text>
            <xsl:text disable-output-escaping="yes">&lt;table name=""&gt;</xsl:text>
            <xsl:text>&#xa;</xsl:text>
            <xsl:for-each select="RESULTS/ROW">
                <xsl:for-each select="COLUMN">
                    <xsl:text disable-output-escaping="yes">&lt;column&gt;</xsl:text>
                        <xsl:value-of select="@NAME" />
                    <xsl:text disable-output-escaping="yes">&lt;/column&gt;</xsl:text>
                    <xsl:text>&#xa;</xsl:text>
                </xsl:for-each>
            </xsl:for-each>
            <xsl:for-each select="RESULTS">
                <xsl:for-each select="ROW">
                    <xsl:text disable-output-escaping="yes">&lt;row&gt;</xsl:text>
                        <xsl:for-each select="COLUMN">
                            <xsl:text disable-output-escaping="yes">&lt;value descriptor="</xsl:text>
                            <xsl:value-of select="@NAME"/>
                            <xsl:text disable-output-escaping="yes">"&gt;</xsl:text>
                            <xsl:choose>
                                <xsl:when test="@NAME='NAME'">
                                    <xsl:value-of select="dbutil:generateRandomName()" />
                                </xsl:when>
                                <xsl:when test="@NAME='MEMBER_SSN'">
                                    <xsl:value-of select="dbutil:generateRandomSsn()" />
                                </xsl:when>
                                <xsl:when test="@NAME='SPOUSE_SSN'">
                                    <xsl:variable name="spouseSsn">
                                        <xsl:value-of select="." />
                                    </xsl:variable>
                                    <xsl:if test="dbutil:hasSpouseSsn($spouseSsn)"><xsl:value-of select="dbutil:generateRandomSsn()" /></xsl:if>
                                </xsl:when>
                                <xsl:when test="@NAME=E_MAIL_ADDRESS">
                                    <xsl:text>noname@mail.com</xsl:text>
                                </xsl:when>
                                <xsl:otherwise>
                                    <xsl:value-of select="." />
                                </xsl:otherwise>
                            </xsl:choose>
                            <xsl:text disable-output-escaping="yes">&lt;/value&gt;</xsl:text>
                            <xsl:text>&#xa;</xsl:text>
                        </xsl:for-each>
                        <xsl:text>&#xa;</xsl:text>
                    <xsl:text disable-output-escaping="yes">&lt;/row&gt;</xsl:text>
                    <xsl:text>&#xa;</xsl:text>
                </xsl:for-each>
            </xsl:for-each>
            <xsl:text disable-output-escaping="yes">&lt;/table&gt;</xsl:text>
            <xsl:text>&#xa;</xsl:text>
        <xsl:text disable-output-escaping="yes">&lt;/dataset&gt;</xsl:text>
        <xsl:text>&#xa;</xsl:text>
    </xsl:template>
</xsl:stylesheet>

我打电话给某些&#34;后端&#34;因此,我不会在我的测试集中嵌入人们的私人信息。

不幸的是,通过/ RESULTS / ROW的第一个循环应该只是循环通过/ RESULT / ROW的第一个子节点的列。

谁能告诉我如何让第一个孩子接受?

1 个答案:

答案 0 :(得分:2)

  

不幸的是,通过/ RESULTS / ROW的第一个循环应该只是一个   循环遍历/ RESULT / ROW的第一个子项的列。

     

谁能告诉我如何让第一个孩子接受?

<强>替换

        <xsl:for-each select="RESULTS/ROW">
            <xsl:for-each select="COLUMN">
              .  .  .  .  .  .  .  .  .  
           </xsl:for-each>
        </xsl:for-each>

<强>与

        <xsl:for-each select="RESULTS/ROW[1]/Column">
              .  .  .  .  .  .  .  .  .  
        </xsl:for-each>