Определение явных функций преобразования в запросах XPath (SQLXML 4.0)
Область применения: SQL Server База данных SQL Azure
Следующие примеры показывают, как явные функции преобразования указываются в запросах XPath. В данных примерах запросы XPath определены в соответствии со схемой сопоставления, которая содержится в файле SampleSchema1.xml. Дополнительные сведения об этой схеме см. в примере аннотированной схемы XSD для примеров XPath (SQLXML 4.0).
Примеры
А. Используйте функцию явного преобразования number()
Функция number() преобразует аргумент в число.
Если значение ContactID не является числом, следующий запрос преобразует ContactID в число и сравнивает его со значением 4. Затем запрос возвращает все <дочерние элементы Employee> узла контекста с атрибутом ContactID с числовым значением 4:
/child::Contact[number(attribute::ContactID)= 4]
Ярлык для оси атрибута (@) можно указать, и так как дочерняя ось является по умолчанию, ее можно исключить из запроса:
/Contact[number(@ContactID) = 4]
В реляционных терминах запрос возвращает сотрудника с Контактным идентификатором 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"]
Ярлык для оси атрибута (@) можно указать, и так как дочерняя ось является по умолчанию, ее можно исключить из запроса:
/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>