XPath 쿼리에 축 지정(SQLXML 4.0)
다음 예에서는 XPath 쿼리에 축을 지정하는 방법을 보여 줍니다.
이 예의 XPath 쿼리는 SampleSchema1.xml에 포함된 매핑 스키마에 대해 지정되었습니다. 이 샘플 스키마에 대한 자세한 내용은 XPath 예제에 대한 샘플 주석 XSD 스키마(SQLXML 4.0)를 참조하세요.
예제
A. 컨텍스트 노드의 자식 요소 검색
다음 XPath 쿼리는 컨텍스트 노드의 <모든 Contact> 자식 요소를 선택합니다.
/child::Contact
쿼리에서 는 child
축이고 Contact
는 노드 테스트입니다(요소가 요소> 노드인 경우<Contact
는 축과 child
연결된 기본 노드 형식이므로 TRUE).<>
기본값은 child
축입니다. 따라서 다음과 같이 쿼리를 작성할 수 있습니다.
/Contact
매핑 스키마에 대해 XPath 쿼리를 테스트하려면
샘플 스키마 코드를 복사하여 텍스트 파일에 붙여넣습니다. 파일을 SampleSchema1.xml로 저장합니다.
다음 템플릿(XPathAxesSampleA.xml)을 만들어 SampleSchema1.xml이 저장된 디렉터리에 저장합니다.
<ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql"> <sql:xpath-query mapping-schema="SampleSchema1.xml"> /Contact </sql:xpath-query> </ROOT>
매핑 스키마(SampleSchema1.xml)에 대해 지정된 디렉터리 경로는 템플릿이 저장된 디렉터리에 상대적입니다. 또한 다음과 같이 절대 경로를 지정할 수 있습니다.
mapping-schema="C:\MyDir\SampleSchema1.xml"
SQLXML 4.0 테스트 스크립트(Sqlxml4test.vbs)를 만든 다음 이 스크립트를 사용하여 템플릿을 실행합니다.
자세한 내용은 ADO를 사용하여 SQLXML 4.0 쿼리 실행을 참조하세요.
다음은 템플릿 실행 결과 집합의 일부입니다.
<ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">
<Contact ContactID="1" LastName="Achong" FirstName="Gustavo" Title="Mr." />
<Contact ContactID="2" LastName="Abel" FirstName="Catherine" Title="Ms." />
<Contact ContactID="3" LastName="Abercrombie" FirstName="Kim" Title="Ms." />
<Contact ContactID="4" LastName="Acevedo" FirstName="Humberto" Title="Sr." />
...
</ROOT>
B. 컨텍스트 노드의 손자 검색
다음 XPath 쿼리는 컨텍스트 노드의 <Customer 요소 자식에 대한 모든 Order> 요소 자식을 선택합니다.<>
/child::Customer/child::Order
쿼리에서 는 child
축이고 Customer
Order
는 노드 테스트입니다(요소 노드가 축의 기본 노드이기 때문에 <> Customer 및 Order가 <요소> 노드인 경우 이러한 노드 child
테스트는 TRUE임). 고객과 일치하는 각 노드에 대해 주문>과 일치하는< 노드가 결과에 추가됩니다.<> 결과 집합에는 Order>만< 반환됩니다.
기본값은 child
축입니다. 따라서 다음과 같이 쿼리를 지정할 수 있습니다.
/Customer/Order
매핑 스키마에 대해 XPath 쿼리를 테스트하려면
샘플 스키마 코드를 복사하여 텍스트 파일에 붙여넣습니다. 파일을 SampleSchema1.xml로 저장합니다.
다음 템플릿(XPathAxesSampleB.xml)을 만들고 다음과 같은 디렉터리에 저장합니다.
<ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql"> <sql:xpath-query mapping-schema="SampleSchema1.xml"> /Customer/Order </sql:xpath-query> </ROOT>
매핑 스키마(SampleSchema1.xml)에 대해 지정된 디렉터리 경로는 템플릿이 저장된 디렉터리에 상대적입니다. 또한 다음과 같이 절대 경로를 지정할 수 있습니다.
mapping-schema="C:\MyDir\SampleSchema1.xml"
SQLXML 4.0 테스트 스크립트(Sqlxml4test.vbs)를 만든 다음 이 스크립트를 사용하여 템플릿을 실행합니다.
자세한 내용은 ADO를 사용하여 SQLXML 4.0 쿼리 실행을 참조하세요.
다음은 템플릿 실행 결과 집합의 일부입니다.
<ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">
<Order SalesOrderID="Ord-43860" SalesPersonID="280"
OrderDate="2001-08-01T00:00:00"
DueDate="2001-08-13T00:00:00"
ShipDate="2001-08-08T00:00:00">
<OrderDetail ProductID="Prod-729" UnitPrice="226.8571"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-732" UnitPrice="440.1742"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-738" UnitPrice="220.2496"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-753" UnitPrice="2576.3544"
OrderQty="2" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-756" UnitPrice="1049.7528"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-758" UnitPrice="1049.7528"
OrderQty="2" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-761" UnitPrice="503.3507"
OrderQty="2" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-762" UnitPrice="503.3507"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-763" UnitPrice="503.3507"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-765" UnitPrice="503.3507"
OrderQty="2" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-768" UnitPrice="503.3507"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-770" UnitPrice="503.3507"
OrderQty="1" UnitPriceDiscount="0" />
</Order>
...
</ROOT>
XPath 쿼리가 고객과> 일치하는< 각 노드에서 로 Customer/Order/OrderDetail
지정된 경우 쿼리는 해당< Order> 요소로 이동합니다. 또한 Order>와 일치하는< 각 노드에 대해 쿼리는 결과에 OrderDetail> 노드를 추가합니다<. OrderDetail>만< 결과 집합에 반환됩니다.
C. ..를 사용하여 부모 축 지정
다음 쿼리는 CustomerID 특성 값이 1인 부모< Customer> 요소가 있는 모든 Order> 요소를 검색합니다.< 쿼리는 조건자의 child
축을 사용하여 Order> 요소의< 부모를 찾습니다.
/child::Customer/child::Order[../@CustomerID="1"]
기본값은 child
축입니다. 따라서 다음과 같이 쿼리를 지정할 수 있습니다.
/Customer/Order[../@CustomerID="1"]
이 XPath 쿼리는 다음과 같습니다.
/Customer[@CustomerID="1"]/Order.
참고
XPath 쿼리 /Order[../@CustomerID="1"]
는 Order의 <부모가 없으므로 오류를 반환합니다>. 매핑 스키마에 Order>를 포함하는< 요소가 있을 수 있지만 XPath는 그 중 어느 요소에서도 시작되지 않았습니다. 따라서 <Order>는 문서의 최상위 요소 형식으로 간주됩니다.
매핑 스키마에 대해 XPath 쿼리를 테스트하려면
샘플 스키마 코드를 복사하여 텍스트 파일에 붙여넣습니다. 파일을 SampleSchema1.xml로 저장합니다.
다음 템플릿(XPathAxesSampleC.xml)을 만들고 다음과 같은 디렉터리에 저장합니다.
<ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql"> <sql:xpath-query mapping-schema="SampleSchema1.xml"> /Customer/Order[../@CustomerID="1"] </sql:xpath-query> </ROOT>
매핑 스키마(SampleSchema1.xml)에 대해 지정된 디렉터리 경로는 템플릿이 저장된 디렉터리에 상대적입니다. 또한 다음과 같이 절대 경로를 지정할 수 있습니다.
mapping-schema="C:\MyDir\SampleSchema1.xml"
SQLXML 4.0 테스트 스크립트(Sqlxml4test.vbs)를 만든 다음 이 스크립트를 사용하여 템플릿을 실행합니다.
자세한 내용은 ADO를 사용하여 SQLXML 4.0 쿼리 실행을 참조하세요.
다음은 템플릿 실행 결과 집합의 일부입니다.
<ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">
<Order SalesOrderID="Ord-43860" SalesPersonID="280"
OrderDate="2001-08-01T00:00:00"
DueDate="2001-08-13T00:00:00"
ShipDate="2001-08-08T00:00:00">
<OrderDetail ProductID="Prod-729" UnitPrice="226.8571"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-732" UnitPrice="440.1742"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-738" UnitPrice="220.2496"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-753" UnitPrice="2576.3544"
OrderQty="2" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-756" UnitPrice="1049.7528"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-758" UnitPrice="1049.7528"
OrderQty="2" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-761" UnitPrice="503.3507"
OrderQty="2" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-762" UnitPrice="503.3507"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-763" UnitPrice="503.3507"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-765" UnitPrice="503.3507"
OrderQty="2" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-768" UnitPrice="503.3507"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-770" UnitPrice="503.3507"
OrderQty="1" UnitPriceDiscount="0" />
</Order>
...
</Order>
</ROOT>
D. 특성 축 지정
다음 XPath 쿼리는 CustomerID 특성 값이<> 1인 컨텍스트 노드의 모든 Customer 자식 요소를 선택합니다.
/child::Customer[attribute::CustomerID="1"]
조건자attribute::CustomerID
에서 는 attribute
축이고 CustomerID
는 노드 테스트입니다(가 특성인 경우 CustomerID
특성 노드는 축의<> 기본 노드 attribute
이므로 노드 테스트는 TRUE임).
attribute
축에 대한 바로 가기(@)를 지정할 수 있으며 child
축은 기본 축이므로 쿼리에서 생략할 수 있습니다.
/Customer[@CustomerID="1"]
매핑 스키마에 대해 XPath 쿼리를 테스트하려면
샘플 스키마 코드를 복사하여 텍스트 파일에 붙여넣습니다. 파일을 SampleSchema1.xml로 저장합니다.
다음 템플릿(XPathAxesSampleD.xml)을 만들어 SampleSchema1.xml이 저장된 디렉터리에 저장합니다.
<ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql"> <sql:xpath-query mapping-schema="SampleSchema1.xml"> child::Customer[attribute::CustomerID="1"] </sql:xpath-query> </ROOT>
매핑 스키마(SampleSchema1.xml)에 대해 지정된 디렉터리 경로는 템플릿이 저장된 디렉터리에 상대적입니다. 또한 다음과 같이 절대 경로를 지정할 수 있습니다.
mapping-schema="C:\MyDir\SampleSchema1.xml"
SQLXML 4.0 테스트 스크립트(Sqlxml4test.vbs)를 만든 다음 이 스크립트를 사용하여 템플릿을 실행합니다.
자세한 내용은 ADO를 사용하여 SQLXML 4.0 쿼리 실행을 참조하세요.
다음은 템플릿 실행 결과 집합의 일부입니다.
<ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql">
<Customer CustomerID="1" SalesPersonID="280"
TerritoryID="1" AccountNumber="1"
CustomerType="S" Orders="Ord-43860 Ord-44501 Ord-45283 Ord-46042">
<Order SalesOrderID="Ord-43860" SalesPersonID="280"
OrderDate="2001-08-01T00:00:00"
DueDate="2001-08-13T00:00:00"
ShipDate="2001-08-08T00:00:00">
<OrderDetail ProductID="Prod-729" UnitPrice="226.8571"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-732" UnitPrice="440.1742"
OrderQty="1" UnitPriceDiscount="0" />
<OrderDetail ProductID="Prod-738" UnitPrice="220.2496"
OrderQty="1" UnitPriceDiscount="0" />
...
</Order>
...
</Customer>
</ROOT>