次の方法で共有


XPath クエリでの明示的な変換関数の指定 (SQLXML 4.0)

次の例は、XPath クエリで明示的な変換関数を指定する方法を示しています。 これらの例の XPath クエリは、SampleSchema1.xmlに含まれるマッピング スキーマに対して指定されます。 このサンプル スキーマの詳細については、「 XPath のサンプル注釈付き XSD スキーマ (SQLXML 4.0)」を参照してください。

例示

A。 number() 明示的な変換関数を使用する

number()関数は、引数を数値に変換します。

ContactID の値が数値以外であると仮定すると、次のクエリは ContactID を数値に変換し、値 4 と比較します。 その後、クエリは、数値が 4 の ContactID 属性を持つコンテキスト ノードのすべての <Employee> 要素の子を返します。

/child::Contact[number(attribute::ContactID)= 4]  

attribute軸 (@) へのショートカットを指定できます。また、child軸が既定値であるため、クエリから省略できます。

/Contact[number(@ContactID) = 4]  

リレーショナル用語では、クエリは ContactID が 4 の従業員を返します。

マッピング スキーマに対して XPath クエリをテストするには
  1. サンプル スキーマ コードをコピーし、テキスト ファイルに貼り付けます。 ファイルを SampleSchema1.xmlとして保存します。

  2. 次のテンプレート (ExplicitConversionA.xml) を作成し、SampleSchema1.xml が保存されたディレクトリに保存します。

    <ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">  
      <sql:xpath-query mapping-schema="SampleSchema1.xml">  
        /Contact[number(@ContactID)=4]  
      </sql:xpath-query>  
    </ROOT>  
    

    マッピング スキーマ (SampleSchema1.xml) に指定されたディレクトリ パスは、テンプレートが保存されているディレクトリに対する相対パスです。 次のように、絶対パスを指定することもできます。

    mapping-schema="C:\MyDir\SampleSchema1.xml"  
    
  3. SQLXML 4.0 テスト スクリプト (sqlxml4test.vbs) を作成し、それを使用してテンプレートを実行します。

    詳細については、「ADO を使用した SQLXML 4.0 クエリの実行」を参照してください。

このテンプレート実行の結果セットは次のとおりです。

<ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">  
  <Contact ContactID="4" LastName="Acevedo" FirstName="Humberto" Title="Sr." />   
</ROOT>  

B. string() 明示的な変換関数を使用する

string()関数は、引数を文字列に変換します。

次のクエリでは 、ContactID を文字列に変換し、文字列値 "4" と比較します。 このクエリは、文字列値が "4" の ContactID を持つコンテキスト ノードのすべての<Employee>要素の子を返します。

/child::Contact[string(attribute::ContactID)="4"]  

attribute軸 (@) へのショートカットを指定できます。また、child軸が既定値であるため、クエリから省略できます。

/Contact[string(@ContactID)="4"]  

機能的には、このクエリは前のクエリ例と同じ結果を返しますが、評価は数値 (つまり、数値 4) ではなく文字列値に対して行われます。

マッピング スキーマに対して XPath クエリをテストするには
  1. サンプル スキーマ コードをコピーし、テキスト ファイルに貼り付けます。 ファイルを SampleSchema1.xmlとして保存します。

  2. 次のテンプレート (ExplicitConversionB.xml) を作成し、SampleSchema1.xml が保存されたディレクトリに保存します。

    <ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">  
      <sql:xpath-query mapping-schema="SampleSchema1.xml">  
        Contact[string(@ContactID)="4"]  
      </sql:xpath-query>  
    </ROOT>  
    

    マッピング スキーマ (SampleSchema1.xml) に指定されたディレクトリ パスは、テンプレートが保存されているディレクトリに対する相対パスです。 次のように、絶対パスを指定することもできます。

    mapping-schema="C:\MyDir\SampleSchema1.xml"  
    
  3. SQLXML 4.0 テスト スクリプト (sqlxml4test.vbs) を作成し、それを使用してテンプレートを実行します。

    詳細については、「ADO を使用した SQLXML 4.0 クエリの実行」を参照してください。

テンプレート実行の結果セットを次に示します。

<ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">  
  <Contact ContactID="4" LastName="Acevedo" FirstName="Humberto" Title="Sr." />   
</ROOT>