1

以下のようなXMLファイルがあります...

<?xml version='1.0'?>
<T0020 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://www.safersys.org/namespaces/T0020V1 T0020V1.xsd"
    xmlns="http://www.safersys.org/namespaces/T0020V1">

    <IRP_ACCOUNT>
        <IRP_CARRIER_ID_NUMBER>1213561</IRP_CARRIER_ID_NUMBER>
        <IRP_BASE_COUNTRY>US</IRP_BASE_COUNTRY>
        <IRP_BASE_STATE>AL</IRP_BASE_STATE>
        <IRP_ACCOUNT_NUMBER>15485</IRP_ACCOUNT_NUMBER>
        <IRP_ACCOUNT_TYPE>I</IRP_ACCOUNT_TYPE>
        <IRP_STATUS_CODE>0</IRP_STATUS_CODE>
        <IRP_STATUS_DATE>2004-02-23</IRP_STATUS_DATE>
        <IRP_UPDATE_DATE>2007-03-09</IRP_UPDATE_DATE>
        <IRP_NAME>
            <NAME_TYPE>LG</NAME_TYPE>
            <NAME>WILLIAMS TODD</NAME>
            <IRP_ADDRESS>
                <ADDRESS_TYPE>MA</ADDRESS_TYPE>
                <STREET_LINE_1>P O BOX 1210</STREET_LINE_1>
                <STREET_LINE_2/>
                <CITY>MARION</CITY>
                <STATE>AL</STATE>
                <ZIP_CODE>36756</ZIP_CODE>
                <COUNTY/>
                <COLONIA/>
                <COUNTRY>US</COUNTRY>
            </IRP_ADDRESS>
        </IRP_NAME>
    </IRP_ACCOUNT>
</T0020>

このXMLデータをデータベースに挿入するために、2つのXSLTを使用しました。最初のXSLTは、XMLファイルから名前空間を削除し、このXMLを一時的な場所にある中間XML(たとえばProcess.xml)ファイルに変換します。

次に、その中間xml(名前空間行なし)を取得し、別のXSLを適用してxmlフィールドをデータベースにマップしました。

次に、解決策を見つけ、[1]名前空間の削除と[2] XMLフィールドのデータベースへのマッピングの前兆となるXSLTを1つだけ使用して、データを挿入しました。

最終的なスタイルシートには、次の行が含まれています

xmlns:t="http://www.safersys.org/namespaces/T0020V1">

そして、以下を使用してフィールドをデータベースにマップしました

  <xsl:template match="/">
       <xsl:element name="T0020">
           <xsl:apply-templates select="t:T0020/t:IRP_ACCOUNT" /> 
      </xsl:element>
 </xsl:template>

このアプローチで問題はどのように解決されましたか?これを使用した場合の影響はありますか?私はこれについて検索しましたが、機能を取得していません。

前もって感謝します..

4

1 に答える 1

2

あなたのアプローチに問題はありません。

XSLTは、正しく一致するために完全修飾名を義務付けているため、XSLTでプレフィックス付きの名前空間を使用することが適切なソリューションです。これがあなたがあなたの問題を解決した理由です。

于 2010-01-08T12:01:49.120 に答える