Mit problem er meget simplet. JEg henter noget data fra en XMl file som jeg kan smide i en database DB2. Så jeg bruger min XSL til at lave alle insert-sætninger.
Men da der kan forekomme ' i mit XMl, hvilket så gør at der kommer problemer og jeg kan ikke sætte noget ind. Så jeg skal havde lavet alle ' om til '' (to '' efter hinanden).
Jeg har følgede kode:
<?xml version="1.0" encoding="ISO-8859-1"?>
<xsl:stylesheet 
    version="1.0" 
    xmlns:xsl="
http://www.w3.org/1999/XSL/Transform">
  <xsl:template name="string-replace">
    <xsl:param name="text"/>
    <xsl:param name="replace"/>
    <xsl:param name="with"/>
    <xsl:choose>
      <xsl:when test="contains($text,$replace)">
        <xsl:value-of select="substring-before($text,$replace)"/>
        <xsl:value-of select="$with"/>
        <xsl:call-template name="string-replace">
          <xsl:with-param name="text" select="substring-after($text,$replace)"/>
          <xsl:with-param name="replace" select="$replace"/>
          <xsl:with-param name="with" select="$with"/>
        </xsl:call-template>
      </xsl:when>
      <xsl:otherwise>
        <xsl:value-of select="$text"/>
      </xsl:otherwise>
    </xsl:choose>
  </xsl:template>
<xsl:template match="/">
    <xsl:for-each select="tforhandler/forhandler">
        |<xsl:value-of select="cmaerkesites"/>|
        <br/>
        <xsl:call-template name="string-replace">
            <xsl:with-param name="text" select="cmaerkesites"/>
            <xsl:with-param name="replace" select="'VW'"/>
            <xsl:with-param name="with" select="<![CDATA[']]>"/>
        </xsl:call-template>    
        <br/>
        <![CDATA[']]>
    </xsl:for-each>
</xsl:template>
</xsl:stylesheet>