Поделиться через


Определение явных функций преобразования в запросах XPath (SQLXML 4.0)

Следующие примеры показывают, как явные функции преобразования указываются в запросах XPath. В данных примерах запросы XPath определены в соответствии со схемой сопоставления, которая содержится в файле SampleSchema1.xml. Сведения об этом образце схемы см. в разделе Образец схемы XSD с заметками для примеров XPath (SQLXML 4.0).

Примеры

А. Используйте функцию явного преобразования number()

Функция number() преобразует аргумент в число.

Предполагая, что значение BusinessEntityID не является числовым, следующий запрос преобразует BusinessEntityID в число и сравнивает его со значением 4. Запрос возвращает все дочерние элементы <Employee> узла контекста с атрибутом BusinessEntityID, имеющим числовое значение 4.

/child::Person[number(attribute::BusinessEntityID)= 4]

Можно указать сочетание клавиш для оси attribute (@), а поскольку ось child является осью по умолчанию, в запросе ее можно опустить:

/Person[number(@BusinessEntityID) = 4]

В терминах реляционной базы данных запрос возвращает работника с BusinessEntityID, равным 4.

Проверка запроса XPath к схеме сопоставления

  1. Скопируйте образец кода схемы и вставьте его в текстовый файл. Сохраните файл с именем SampleSchema1.xml.

  2. Создайте следующий шаблон (ExplicitConversionA.xml) и сохраните его в каталоге, в котором сохранен файл SampleSchema1.xml.

    <ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">
      <sql:xpath-query mapping-schema="SampleSchema1.xml">
        /Contact[number(@BusinessEntityID)=4]
      </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">
  <Person BusinessEntityID="4" LastName="Acevedo" FirstName="Humberto" Title="Sr." /> 
</ROOT>

Б. Используйте функцию явного преобразования string()

Функция string() преобразует аргумент в строку.

Следующий запрос преобразует BusinessEntityID в строку и сравнивает ее со строковым значением 4. Запрос возвращает все дочерние элементы <Employee> узла контекста с BusinessEntityID, имеющим строковое значение 4:

/child::Contact[string(attribute::BusinessEntityID)="4"]

Можно указать сочетание клавиш для оси attribute (@), а поскольку ось child является осью по умолчанию, в запросе ее можно опустить:

/Contact[string(@BusinessEntityID)="4"]

С функциональной точки зрения этот запрос возвращает те же результаты, что и предыдущий пример запроса, хотя выполняется сопоставление со строковым значением, а не числовым значением (то есть числом 4).

Проверка запроса XPath к схеме сопоставления

  1. Скопируйте образец кода схемы и вставьте его в текстовый файл. Сохраните файл с именем SampleSchema1.xml.

  2. Создайте следующий шаблон (ExplicitConversionB.xml) и сохраните его в каталоге, в котором сохранен файл SampleSchema1.xml.

    <ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">
      <sql:xpath-query mapping-schema="SampleSchema1.xml">
        Person[string(@BusinessEntityID)="4"]
      </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">
  <Person BusinessEntityID="4" LastName="Acevedo" FirstName="Humberto" Title="Sr." /> 
</ROOT>