在 XPath 查詢中指定關係運算子 (SQLXML 4.0)
下列範例示範如何在 XPath 查詢中指定關係運算子。這些範例中的 XPath 查詢是針對 SampleSchema1.xml 中包含的對應結構描述所指定。如需有關此範例結構描述的詳細資訊,請參閱<XPath 範例的範例註解式 XSD 結構描述 (SQLXML 4.0)>。
範例
A. 指定關係運算子
這個 XPath 查詢會傳回 <Customer> 元素的子元素,其中 CustomerID 屬性值為 "1" 而且任何子 <Order> 元素都包含 OrderQty 屬性值大於 3 的 <OrderDetail> 子系:
/child::Customer[@CustomerID="1"]/Order/OrderDetail[@OrderQty > 3]
在方括號中指定的述詞會篩選 <Customer> 元素。只會傳回至少有一個 OrderQty 屬性值大於 3 之 <OrderDetail> 孫系的 <Customer> 元素。
child 軸是預設值。因此,此查詢可以指定為:
/Customer[@CustomerID="1"]/Order/OrderDetail[@OrderQty > 3]
若要針對對應的結構描述測試 XPath 查詢
複製範例結構描述程式碼,並將其貼至文字檔中。將檔案儲存為 SampleSchema1.xml。
建立下列範本 (SpecifyRelationalA.xml),並將其儲存在儲存 SampleSchema1.xml 的目錄中。
<ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql"> <sql:xpath-query mapping-schema="SampleSchema1.xml"> /Customer[@CustomerID="1"]/Order/OrderDetail[@OrderQty > 3] </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">
<OrderDetail ProductID="Prod-760" UnitPrice="503.3507" OrderQty="4" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-763" UnitPrice="503.3507" OrderQty="4" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-766" UnitPrice="503.3507" OrderQty="4" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-732" UnitPrice="440.1742" OrderQty="4" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-757" UnitPrice="1049.7528" OrderQty="4" UnitPriceDiscount="0" />
</ROOT>
B. 在 XPath 查詢中指定關係運算子並使用布林函數來比較結果
這個查詢會傳回內容節點中 SalesPersonID 屬性值小於 270 的所有 <Order> 元素子系:
/child::Customer/child::Order[(attribute::SalesPersonID < 270)=true()]
您可以指定 attribute 軸的捷徑 (@),而且因為 child 軸是預設值,因此可在查詢中省略:
/Customer/Order[(@SalesPersonID < 270)=true()]
[!附註]
在範本中指定這個查詢時,< 字元必須進行實體編碼,因為 < 字元在 XML 文件中具有特殊意義。在範本中,請使用 < 來指定 < 字元。
若要針對對應的結構描述測試 XPath 查詢
複製範例結構描述程式碼,並將其貼至文字檔中。將檔案儲存為 SampleSchema1.xml。
建立下列範本 (SpecifyRelationalB.xml),並將其儲存在儲存 SampleSchema1.xml 的目錄中。
<ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql"> <sql:xpath-query mapping-schema="SampleSchema1.xml"> /Customer/Order[(@SalesPersonID<270)=true()] </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">
<Order SalesOrderID="Ord-46613" SalesPersonID="268"
OrderDate="2002-07-01T00:00:00"
DueDate="2002-07-13T00:00:00"
ShipDate="2002-07-08T00:00:00">
<OrderDetail ProductID="Prod-739" UnitPrice="917.9363"
OrderQty="2" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-779" UnitPrice="1491.4221"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-825" UnitPrice="242.1391"
OrderQty="1" UnitPriceDiscount="0" />
</Order>
<Order SalesOrderID="Ord-71919" SalesPersonID="268"
OrderDate="2004-06-01T00:00:00"
DueDate="2004-06-13T00:00:00"
ShipDate="2004-06-08T00:00:00">
<OrderDetail ProductID="Prod-961" UnitPrice="534.492"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-965" UnitPrice="534.492"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-966" UnitPrice="1716.5304"
OrderQty="1" UnitPriceDiscount="0" />
</Order>
...
</ROOT>