XQuery에서 네임스페이스 처리
적용 대상: SQL Server
이 항목에서는 쿼리에서 네임스페이스를 처리하기 위한 샘플을 제공합니다.
예제
A. 네임스페이스 선언
다음 쿼리는 특정 제품 모델의 제조 단계를 검색합니다.
SELECT Instructions.query('
declare namespace AWMI="https://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelManuInstructions";
/AWMI:root/AWMI:Location[1]/AWMI:step
') as x
FROM Production.ProductModel
WHERE ProductModelID=7
다음은 결과의 일부입니다.
<AWMI:step xmlns:AWMI="https://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelManuInstructions">Insert <AWMI:material>aluminum sheet MS-2341</AWMI:material> into the <AWMI:tool>T-85A framing tool</AWMI:tool>. </AWMI:step>
...
네임스페이스 키워드는 새 네임스페이스 접두사 "AWMI:"를 정의하는 데 사용됩니다. 그런 다음 해당 네임스페이스의 범위에 포함되는 모든 요소에 대해 쿼리에서 이 접두사를 사용해야 합니다.
B. 기본 네임스페이스 선언
이전 쿼리에서 새 네임스페이스 접두사를 정의했습니다. 그런 다음 쿼리에서 해당 접두사를 사용하여 의도한 XML 구조를 선택해야 했습니다. 이 방법 외에 다음 수정된 쿼리에서와 같이 네임스페이스를 기본 네임스페이스로 선언할 수 있습니다.
SELECT Instructions.query('
declare default element namespace "https://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelManuInstructions";
/root/Location[1]/step
') as x
FROM Production.ProductModel
where ProductModelID=7
다음은 결과입니다.
<step xmlns="http://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelManuInstructions">Insert <material>aluminum sheet MS-2341</material> into the <tool>T-85A framing tool</tool>. </step>
...
이 예제에서는 정의된 "https://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelManuInstructions"
네임스페이스가 기본 네임스페이스 또는 비어 있는 네임스페이스를 재정의하도록 만들어집니다. 이 때문에 쿼리에 사용되는 경로 식에 더 이상 네임스페이스 접두사가 없습니다. 또한 결과에 표시되는 요소 이름에도 네임스페이스 접두사가 더 이상 없습니다. 또한 기본 네임스페이스는 모든 요소에 적용되지만 해당 특성에는 적용되지 않습니다.
C. XML 생성에서 네임스페이스 사용
새 네임스페이스를 정의하면 쿼리뿐만 아니라 생성에 대한 범위로 가져옵니다. 예를 들어 XML을 생성할 때 "declare namespace ...
" 선언을 사용하여 새 네임스페이스를 정의한 다음 생성한 요소 및 특성과 함께 해당 네임스페이스를 사용하여 쿼리 결과 내에 표시할 수 있습니다.
SELECT CatalogDescription.query('
declare default element namespace "https://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelDescription";
declare namespace myNS="uri:SomeNamespace";<myNS:Result>
{ /ProductDescription/Summary }
</myNS:Result>
') as Result
FROM Production.ProductModel
where ProductModelID=19
다음은 결과입니다.
<myNS:Result xmlns:myNS="uri:SomeNamespace">
<Summary xmlns="http://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelDescription">
<p1:p xmlns:p1="http://www.w3.org/1999/xhtml">
Our top-of-the-line competition mountain bike. Performance-enhancing
options include the innovative HL Frame, super-smooth front
suspension, and traction for all terrain.</p1:p>
</Summary>
</myNS:Result>
또는 다음 쿼리와 같이 XML 생성의 일부로 사용되는 각 지점에서 네임스페이스를 명시적으로 정의할 수도 있습니다.
SELECT CatalogDescription.query('
declare default element namespace "https://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelDescription";
<myNS:Result xmlns:myNS="uri:SomeNamespace">
{ /ProductDescription/Summary }
</myNS:Result>
') as Result
FROM Production.ProductModel
where ProductModelID=19
D. 기본 네임스페이스를 사용하여 생성
생성된 XML에서 사용할 기본 네임스페이스를 정의할 수도 있습니다. 예를 들어 다음 쿼리는 요소와 같이 <Result>
생성된 로컬로 명명된 요소의 기본값으로 사용할 기본 네임스페이스 "uri:SomeNamespace"\를 지정하는 방법을 보여 있습니다.
SELECT CatalogDescription.query('
declare namespace PD="https://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelDescription";
declare default element namespace "uri:SomeNamespace";<Result>
{ /PD:ProductDescription/PD:Summary }
</Result>
') as Result
FROM Production.ProductModel
where ProductModelID=19
다음은 결과입니다.
<Result xmlns="uri:SomeNamespace">
<PD:Summary xmlns:PD="https://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelDescription">
<p1:p xmlns:p1="http://www.w3.org/1999/xhtml">
Our top-of-the-line competition mountain bike. Performance-
enhancing options include the innovative HL Frame, super-smooth
front suspension, and traction for all terrain.</p1:p>
</PD:Summary>
</Result>
기본 요소 네임스페이스 또는 빈 네임스페이스를 재정의하면 생성된 XML의 로컬로 명명된 모든 요소가 나중에 재정의되는 기본 네임스페이스에 바인딩됩니다. 따라서 빈 네임스페이스를 활용하기 위해 XML을 유연하게 생성해야 하는 경우 기본 요소 네임스페이스를 재정의하지 마세요.
참고 항목
WITH XMLNAMESPACES를 사용하여 쿼리에 네임스페이스 추가
XML 데이터(SQL Server)
XQuery 언어 참조(SQL Server)