XPath クエリでの明示変換関数の指定 (SQLXML 4.0)
適用対象: SQL Server Azure SQL データベース
次の例では、XPath クエリに明示変換関数を指定する方法を示します。 これらの例では、SampleSchema1.xml に格納されているマッピング スキーマに対して XPath クエリを指定しています。 このサンプル スキーマの詳細については、「 サンプル XPath Examples (SQLXML 4.0)の注釈付き XSD スキーマを参照してください。
例
A. number() 明示変換関数を使用する
number()関数は、引数を数値に変換します。
ContactIDの値が数値以外であると仮定すると、次のクエリはContactIDを数値に変換し、値 4 と比較します。 次に、このクエリは、ContactID 属性の数値が 4 のコンテキスト ノードのすべての <Employee> 要素の子を返します。
/child::Contact[number(attribute::ContactID)= 4]
attribute軸 (@) へのショートカットを指定できます。また、child 軸が既定値であるため、クエリから省略できます。
/Contact[number(@ContactID) = 4]
リレーショナル用語では、クエリは ContactID 4 の従業員を返します。
マッピング スキーマに対して XPath クエリをテストするには
サンプル スキーマ コードをコピーしテキスト ファイルに貼り付けます。 SampleSchema1.xml として保存します。
次のテンプレート (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"
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" と比較します。 このクエリは、コンテキスト ノードの <Employee> 要素のすべての子を返します。 ContactID 文字列値は "4" です。
/child::Contact[string(attribute::ContactID)="4"]
attribute軸 (@) へのショートカットを指定できます。また、child 軸が既定値であるため、クエリから省略できます。
/Contact[string(@ContactID)="4"]
機能的には、このクエリでは上の例のクエリと同じ結果が返されます。ただし、評価は数値 (4) ではなく文字列に対して行われます。
マッピング スキーマに対して XPath クエリをテストするには
サンプル スキーマ コードをコピーしテキスト ファイルに貼り付けます。 SampleSchema1.xml として保存します。
次のテンプレート (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"
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>