다음을 통해 공유


XPath 쿼리에 관계형 연산자 지정(SQLXML 4.0)

적용 대상: SQL ServerAzure SQL Database

다음 예에서는 XPath 쿼리에 관계형 연산자를 지정하는 방법을 보여 줍니다. 이러한 예제의 XPath 쿼리는 SampleSchema1.xml 포함된 매핑 스키마에 대해 지정됩니다. 이 샘플 스키마에 대한 자세한 내용은 XPath 예제에 대한 주석이 추가된 샘플 XSD 스키마(SQLXML 4.0)를 참조하세요.

예제

A. 관계형 연산자 지정

이 XPath 쿼리는 CustomerID 특성 값이 "1"이고 모든 자식 <Order 요소에 OrderQty> 특성이 3보다 큰 OrderDetail> 자식이 포함된< Customer> 요소의 자식 요소를 <반환합니다.

/child::Customer[@CustomerID="1"]/Order/OrderDetail[@OrderQty > 3]  

대괄호에 지정된 조건자는 Customer> 요소를 필터링합니다<. <OrderQty 특성 값이 3보다 큰 OrderDetail> 손자가 하나< 이상 있는 Customer> 요소만 반환됩니다.

자식 축이 기본값입니다. 따라서 쿼리를 다음과 같이 지정할 수 있습니다.

/Customer[@CustomerID="1"]/Order/OrderDetail[@OrderQty > 3]  
매핑 스키마에 대해 XPath 쿼리를 테스트하려면
  1. 샘플 스키마 코드를 복사하여 텍스트 파일에 붙여넣습니다. 파일을 SampleSchema1.xml 저장합니다.

  2. 다음 템플릿(SpecifyRelationalA.xml)을 만들고 SampleSchema1.xml 저장된 디렉터리에 저장합니다.

    <ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">  
      <sql:xpath-query mapping-schema="SampleSchema1.xml">  
        /Customer[@CustomerID="1"]/Order/OrderDetail[@OrderQty > 3]  
      </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">  
  <OrderDetail ProductID="Prod-760" UnitPrice="503.3507" OrderQty="4" UnitPriceDiscount="0" />   
  <OrderDetail ProductID="Prod-763" UnitPrice="503.3507" OrderQty="4" UnitPriceDiscount="0" />   
  <OrderDetail ProductID="Prod-766" UnitPrice="503.3507" OrderQty="4" UnitPriceDiscount="0" />   
  <OrderDetail ProductID="Prod-732" UnitPrice="440.1742" OrderQty="4" UnitPriceDiscount="0" />   
  <OrderDetail ProductID="Prod-757" UnitPrice="1049.7528" OrderQty="4" UnitPriceDiscount="0" />   
</ROOT>  

B. XPath 쿼리에 관계형 연산자 지정 및 부울 함수를 사용하여 결과 비교

이 쿼리는 SalesPersonID 특성 값이 270보다 작은 컨텍스트 노드의 모든 <Order> 요소 자식을 반환합니다.

/child::Customer/child::Order[(attribute::SalesPersonID < 270)=true()]  

특성 축(@)에 대한 바로 가기를 지정할 수 있으며 자식 축이 기본값이므로 쿼리에서 생략할 수 있습니다.

/Customer/Order[(@SalesPersonID < 270)=true()]  

참고 항목

템플릿 < 에서 이 쿼리를 지정하는 경우 문자는 XML 문서에서 특별한 의미가 있으므로 < 엔터티로 인코딩되어야 합니다. 템플릿에서 문자를 지정 < 하는 데 사용합니다<.

매핑 스키마에 대해 XPath 쿼리를 테스트하려면
  1. 샘플 스키마 코드를 복사하여 텍스트 파일에 붙여넣습니다. 파일을 SampleSchema1.xml 저장합니다.

  2. 다음 템플릿(SpecifyRelationalB.xml)을 만들고 SampleSchema1.xml 저장된 디렉터리에 저장합니다.

    <ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">  
        <sql:xpath-query mapping-schema="SampleSchema1.xml">  
            /Customer/Order[(@SalesPersonID<270)=true()]  
        </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">  
  <Order SalesOrderID="Ord-46613" SalesPersonID="268"   
         OrderDate="2002-07-01T00:00:00"   
         DueDate="2002-07-13T00:00:00"   
         ShipDate="2002-07-08T00:00:00">  
    <OrderDetail ProductID="Prod-739" UnitPrice="917.9363"   
                 OrderQty="2" UnitPriceDiscount="0" />   
    <OrderDetail ProductID="Prod-779" UnitPrice="1491.4221"   
                 OrderQty="1" UnitPriceDiscount="0" />   
    <OrderDetail ProductID="Prod-825" UnitPrice="242.1391"   
                 OrderQty="1" UnitPriceDiscount="0" />   
  </Order>  
  <Order SalesOrderID="Ord-71919" SalesPersonID="268"  
         OrderDate="2004-06-01T00:00:00"   
         DueDate="2004-06-13T00:00:00"   
         ShipDate="2004-06-08T00:00:00">  
    <OrderDetail ProductID="Prod-961" UnitPrice="534.492"   
                 OrderQty="1" UnitPriceDiscount="0" />   
    <OrderDetail ProductID="Prod-965" UnitPrice="534.492"   
                 OrderQty="1" UnitPriceDiscount="0" />   
    <OrderDetail ProductID="Prod-966" UnitPrice="1716.5304"   
                 OrderQty="1" UnitPriceDiscount="0" />   
  </Order>  
  ...  
</ROOT>