Sdílet prostřednictvím


Specifikace booleovských funkcí v XPath dotazech (SQLXML 4.0)

platí pro:SQL Serverazure SQL Database

Následující příklady ukazují, jak jsou Booleovské funkce specifikovány v dotazech XPath. XPath dotazy v těchto příkladech jsou specifikovány vůči mapovacímu schématu obsaženému v SampleSchema1.xml. Pro informace o tomto ukázkovém schématu viz Ukázka anotovaného XSD schématu pro příklady XPath (SQLXML 4.0).

Examples

A. Specifikujte not() Booleovskou funkci

Tento dotaz vrací všechny <podprvky Zákazníka> kontextového uzlu, které nemají <podprvky Order> :

/child::Customer[not(child::Order)]  

Výchozí je podřízená osa. Dotaz tedy lze specifikovat jako:

/Customer[not(Order)]  

Otestování dotazu XPath proti mapovacímu schématu

  1. Zkopírujte ukázkový kód schématu a vložte ho do textového souboru. Uložte soubor jako SampleSchema1.xml.

  2. Vytvořte následující šablonu (BooleanFunctionsA.xml) a uložite ji do adresáře, kde se SampleSchema1.xml ukládá.

    <ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">  
      <sql:xpath-query mapping-schema="SampleSchema1.xml">  
        Customer[not(Order)]  
    </sql:xpath-query>  
    </ROOT>  
    

    Adresářová cesta určená pro mapovací schéma (SampleSchema1.xml) je relativní k adresáři, ve kterém je šablona uložena. Absolutní cestu lze také specifikovat, například:

    mapping-schema="C:\MyDir\SampleSchema1.xml"  
    
  3. Vytvořte a použijte testovací skript SQLXML 4.0 (Sqlxml4test.vbs) k provedení šablony.

    Další informace naleznete v tématu Použití ADO ke spouštění dotazů SQLXML 4.0.

Zde je množina částečných výsledků provedení šablony:

<ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">  
  <Customer CustomerID="13" SalesPersonID="286" TerritoryID="7" AccountNumber="13" CustomerType="S" />   
  <Customer CustomerID="32" SalesPersonID="289" TerritoryID="8" AccountNumber="32" CustomerType="S" />   
  <Customer CustomerID="35" SalesPersonID="275" TerritoryID="2" AccountNumber="35" CustomerType="S" />   
  ...  
</ROOT>  

B. Specifikujte true() a false() booleovské funkce

Tento dotaz vrací všechny <> potomky klientských prvků kontextového uzlu, které nemají <podprvky Order>. Relacionálně tento dotaz vrací všechny zákazníky, kteří ještě žádnou objednávku neprovedli.

/child::Customer[child::Order=false()]  

Výchozí je podřízená osa. Dotaz tedy lze specifikovat jako:

/Customer[Order=false()]  

Tento dotaz je ekvivalentní následujícímu:

/Customer[not(Order)]  

Následující dotaz vrací všechny zákazníky, kteří zadali alespoň jednu objednávku:

/Customer[Order=true()]  

Tento dotaz je ekvivalentní tomuto:

/Customer[Order]  

Otestování dotazu XPath proti mapovacímu schématu

  1. Zkopírujte ukázkový kód schématu a vložte ho do textového souboru. Uložte soubor jako SampleSchema1.xml.

  2. Vytvořte následující šablonu (BooleanFunctionsB.xml) a uložite ji do adresáře, kde se SampleSchema1.xml ukládá.

    <ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">  
      <sql:xpath-query mapping-schema="SampleSchema1.xml">  
        /Customer[Order=false()]  
      </sql:xpath-query>  
    </ROOT>  
    

    Adresářová cesta určená pro mapovací schéma (SampleSchema1.xml) je relativní k adresáři, ve kterém je šablona uložena. Absolutní cestu lze také specifikovat, například:

    mapping-schema="C:\MyDir\SampleSchema1.xml"  
    
  3. Vytvořte a použijte testovací skript SQLXML 4.0 (Sqlxml4test.vbs) k provedení šablony.

    Další informace naleznete v tématu Použití ADO ke spouštění dotazů SQLXML 4.0.

Zde je množina částečných výsledků provedení šablony:

<ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">  
  <Customer CustomerID="13" SalesPersonID="286" TerritoryID="7" AccountNumber="13" CustomerType="S" />   
  <Customer CustomerID="32" SalesPersonID="289" TerritoryID="8" AccountNumber="32" CustomerType="S" />   
  <Customer CustomerID="35" SalesPersonID="275" TerritoryID="2" AccountNumber="35" CustomerType="S" />   
  ...  
</ROOT>