在 XPath 查詢中指定明確轉換函數 (SQLXML 4.0)
下列範例示範如何在 XPath 查詢中指定明確的轉換函式。 這些範例中的 XPath 查詢會針對包含在SampleSchema1.xml中的對應架構來指定。 如需此範例架構的相關信息,請參閱 XPath 範例的範例 XSD 架構範例(SQLXML 4.0)。
範例
A. 使用 number() 明確轉換函式
number() 函式會將自變數轉換成數位。
假設 ContactID 的值不是數值,下列查詢會將 ContactID 轉換成數位,並將它與值 4 進行比較。 然後,此查詢會傳回內容節點的所有 <Employee> 元素子系,其 ContactID 屬性的數值為 4:
/child::Contact[number(attribute::ContactID)= 4]
可以指定屬性軸的快捷方式 (@) ,而且因為子軸是預設值,所以可以從查詢中省略它:
/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」 進行比較。 此查詢會傳回具有字串值為 「4」 之 ContactID 之內容節點的所有< Employee> 元素子系:
/child::Contact[string(attribute::ContactID)="4"]
可以指定屬性軸的快捷方式 (@) ,而且因為子軸是預設值,所以可以從查詢中省略它:
/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>