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


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

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

Примеры

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

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

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

/child::Contact[number(attribute::ContactID)= 4]  

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

/Contact[number(@ContactID) = 4]  

В реляционных терминах запрос возвращает сотрудника с Контактным идентификатором 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(@ContactID)=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">  
  <Contact ContactID="4" LastName="Acevedo" FirstName="Humberto" Title="Sr." />   
</ROOT>  

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

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

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

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

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

/Contact[string(@ContactID)="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">  
        Contact[string(@ContactID)="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">  
  <Contact ContactID="4" LastName="Acevedo" FirstName="Humberto" Title="Sr." />   
</ROOT>