XPath 쿼리에서 부울 함수 지정(SQLXML 4.0)
적용 대상: SQL Server Azure SQL Database
다음 예제에서는 XPath 쿼리에서 부울 함수를 지정하는 방법을 보여 줍니다. 이러한 예제의 XPath 쿼리는 SampleSchema1.xml 포함된 매핑 스키마에 대해 지정됩니다. 이 샘플 스키마에 대한 자세한 내용은 XPath 예제에 대한 주석이 추가된 샘플 XSD 스키마(SQLXML 4.0)를 참조하세요.
예제
A. not() 부울 함수 지정
이 쿼리는 <Order> 자식 요소가 없는< 컨텍스트 노드의 모든 Customer> 자식 요소를 반환합니다.
/child::Customer[not(child::Order)]
자식 축이 기본값입니다. 따라서 쿼리를 다음과 같이 지정할 수 있습니다.
/Customer[not(Order)]
매핑 스키마에 대해 XPath 쿼리를 테스트하려면
샘플 스키마 코드를 복사하여 텍스트 파일에 붙여넣습니다. 파일을 SampleSchema1.xml 저장합니다.
다음 템플릿(BooleanFunctionsA.xml)을 만들고 SampleSchema1.xml 저장된 디렉터리에 저장합니다.
<ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql"> <sql:xpath-query mapping-schema="SampleSchema1.xml"> Customer[not(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">
<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. true() 및 false() 부울 함수 지정
이 쿼리는 Order> 자식 요소가 없는 <컨텍스트 노드의 모든< Customer> 요소 자식을 반환합니다. 관계형 용어로 이 쿼리는 주문을 하지 않은 모든 고객을 반환합니다.
/child::Customer[child::Order=false()]
자식 축이 기본값입니다. 따라서 쿼리를 다음과 같이 지정할 수 있습니다.
/Customer[Order=false()]
이 쿼리는 다음과 같습니다.
/Customer[not(Order)]
다음 쿼리는 하나 이상의 주문을 한 고객을 모두 반환합니다.
/Customer[Order=true()]
이 쿼리는 다음과 같습니다.
/Customer[Order]
매핑 스키마에 대해 XPath 쿼리를 테스트하려면
샘플 스키마 코드를 복사하여 텍스트 파일에 붙여넣습니다. 파일을 SampleSchema1.xml 저장합니다.
다음 템플릿(BooleanFunctionsB.xml)을 만들고 SampleSchema1.xml 저장되는 디렉터리에 저장합니다.
<ROOT xmlns:sql="urn:schemas-microsoft-com:xml-sql"> <sql:xpath-query mapping-schema="SampleSchema1.xml"> /Customer[Order=false()] </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="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>