Udostępnij przez


Określanie operatorów logicznych w kwerendach XPath (SQLXML 4.0)

W poniższym przykładzie przedstawiono operatory logiczne w jaki sposób są określone w kwerendach XPath.Kwerendy XPath w tym przykładzie jest określana względem schematu mapowania zawartych w SampleSchema1.xml.Aby uzyskać informacje na temat tego schematu przykładowych zobacz Przykładowe odnotowany schematu XSD dla przykłady XPath (SQLXML 4.0).

Przykłady

A.Określ operator lub logiczny

Ta kwerenda wyrażenie XPath zwraca <Odbiorcy> elementy podrzędne elementu Węzeł kontekstu z Identyfikator klienta wartość atrybut 13 lub 31:

/child::Customer[attribute::CustomerID="13" or attribute::CustomerID="31"]

Skrót do attribute można określić osi (@), a ponieważ child oś jest ustawieniem domyślnym, można pominąć:

/Customer[@CustomerID="13" or @CustomerID="31"]

W predykacie, attribute jest na osi i CustomerID test węzła (PRAWDA, jeśli jest Identyfikator klienta is an <atrybut> węzeł, ponieważ <atrybut> węzeł jest węzeł główny attribute oś). Filtry predykatu <Odbiorcy> elementy i zwraca tylko te, które spełniają warunki określone w predykacie.

Aby przetestować kwerendy XPath schematem mapowania

  1. Kopia Przykładowy kod schematu i wkleić go do pliku tekstowego.Zapisz plik jako SampleSchema1.xml.

  2. Utwórz następujący szablon (BooleanOperatorsA.xml) i zapisz go w katalogu, w którym zostanie zapisana SampleSchema1.xml.

    <ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">
      <sql:xpath-query mapping-schema="SampleSchema1.xml">
        /Customer[@CustomerID="13" or @CustomerID="31"]
      </sql:xpath-query>
    </ROOT>
    

    To ścieżka do katalogu określonego dla mapowania schematu (SampleSchema1.xml) jest względna w stosunku do katalogu, w którym są zapisywane w szablonie.Ścieżka bezwzględna również można określić, na przykład:

    mapping-schema="C:\MyDir\SampleSchema1.xml"
    
  3. Tworzenie i używanie skryptu testu 4.0 SQLXML (Sqlxml4test.vbs) do wykonać tego szablonu.

    Aby uzyskać więcej informacji zobaczPrzy użyciu obiektu ADO do wykonywania SQLXML bada 4.0.

W tym polu jest zestaw wyników wykonania szablonu:

<ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">
  <Customer CustomerID="13" SalesPersonID="286" TerritoryID="7" AccountNumber="13" CustomerType="S" /> 
  <Customer CustomerID="31" SalesPersonID="286" TerritoryID="7" AccountNumber="31" CustomerType="S" Orders="Ord-51803 Ord-69427">
    <Order SalesOrderID="Ord-51803" SalesPersonID="286" OrderDate="2003-08-01T00:00:00" DueDate="2003-08-13T00:00:00" ShipDate="2003-08-08T00:00:00">
      <OrderDetail ProductID="Prod-718" UnitPrice="1059.31" OrderQty="1" UnitPriceDiscount="0" /> 
      <OrderDetail ProductID="Prod-838" UnitPrice="1059.31" OrderQty="1" UnitPriceDiscount="0" /> 
    </Order>
    <Order SalesOrderID="Ord-69427" SalesPersonID="286" OrderDate="2004-05-01T00:00:00" DueDate="2004-05-13T00:00:00" ShipDate="2004-05-08T00:00:00">
      <OrderDetail ProductID="Prod-835" UnitPrice="440.1742" OrderQty="1" UnitPriceDiscount="0" /> 
    </Order>
  </Customer>
</ROOT>