次の方法で共有


XPath クエリでのブール関数の指定 (SQLXML 4.0)

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

例示

A。 not() ブール関数を指定する

このクエリは、<Order> 子要素を持たないコンテキスト ノードのすべての<Customer>子要素を返します。

/child::Customer[not(child::Order)]  

child軸が既定値です。 そのため、クエリは次のように指定できます。

/Customer[not(Order)]  

マッピング スキーマに対して XPath クエリをテストするには

  1. サンプル スキーマ コードをコピーし、テキスト ファイルに貼り付けます。 ファイルを SampleSchema1.xmlとして保存します。

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

    <ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">  
      <sql:xpath-query mapping-schema="SampleSchema1.xml">  
        Customer[not(Order)]  
    </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">  
  <Customer CustomerID="13" SalesPersonID="286" TerritoryID="7" AccountNumber="13" CustomerType="S" />   
  <Customer CustomerID="32" SalesPersonID="289" TerritoryID="8" AccountNumber="32" CustomerType="S" />   
  <Customer CustomerID="35" SalesPersonID="275" TerritoryID="2" AccountNumber="35" CustomerType="S" />   
  ...  
</ROOT>  

B. true() および false() ブール関数を指定する

このクエリは、<Order> 子要素を持たないコンテキスト ノードのすべての <Customer> 要素の子を返します。 リレーショナル用語では、このクエリは注文を行っていないすべての顧客を返します。

/child::Customer[child::Order=false()]  

child軸が既定値です。 そのため、クエリは次のように指定できます。

/Customer[Order=false()]  

このクエリは、次の数式と同じです。

/Customer[not(Order)]  

次のクエリは、少なくとも 1 つの注文を行ったすべての顧客を返します。

/Customer[Order=true()]  

このクエリは、次のクエリと同じです。

/Customer[Order]  

マッピング スキーマに対して XPath クエリをテストするには

  1. サンプル スキーマ コードをコピーし、テキスト ファイルに貼り付けます。 ファイルを SampleSchema1.xmlとして保存します。

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

    <ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">  
      <sql:xpath-query mapping-schema="SampleSchema1.xml">  
        /Customer[Order=false()]  
      </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">  
  <Customer CustomerID="13" SalesPersonID="286" TerritoryID="7" AccountNumber="13" CustomerType="S" />   
  <Customer CustomerID="32" SalesPersonID="289" TerritoryID="8" AccountNumber="32" CustomerType="S" />   
  <Customer CustomerID="35" SalesPersonID="275" TerritoryID="2" AccountNumber="35" CustomerType="S" />   
  ...  
</ROOT>