다음을 통해 공유


데이터 접근자 함수 - 문자열(XQuery)

적용 대상:SQL Server

문자열로 표시되는 $arg 값을 반환합니다.

구문

fn:string() as xs:string
fn:string($arg as item()?) as xs:string

인수

$arg

노드 또는 원자성 값입니다.

설명

  • $arg 빈 시퀀스인 경우 길이가 0인 문자열이 반환됩니다.

  • $arg 노드인 경우 함수는 문자열-값 접근자를 사용하여 가져온 노드의 문자열 값을 반환합니다. 이는 W3C XQuery 1.0 및 XPath 2.0 데이터 모델 사양에 정의되어 있습니다.

  • $arg 원자성 값이면 함수는 식 캐스트xs:string에서 반환하는 것과 동일한 문자열을 반환합니다. 그렇지 않은 경우를 제외하고 $arg.

  • $arg 형식이xs:anyURI면 특수 문자를 이스케이프하지 않고 URI가 문자열로 변환됩니다.

  • 이 구현 fn:string() 에서는 인수 없이 컨텍스트 종속 조건자의 컨텍스트에서만 사용할 수 있습니다. 특히 대괄호([ ])에서만 사용할 수 있습니다.

예제

이 문서에서는 AdventureWorks 데이터베이스의 다양한 xml 형식 열에 저장된 XML 인스턴스에 대한 XQuery 예제를 제공합니다.

A. 문자열 함수 사용

다음 쿼리는 요소의 <Features> 자식 요소 노드를 검색합니다.<ProductDescription>

SELECT CatalogDescription.query('
declare namespace PD="https://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelDescription";
 /PD:ProductDescription/PD:Features
')
FROM Production.ProductModel
WHERE ProductModelID = 19;

다음은 부분 결과입니다.

<PD:Features xmlns:PD="https://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelDescription">
   These are the product highlights.
   <p1:Warranty xmlns:p1="https://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelWarrAndMain">
    <p1:WarrantyPeriod>3 years</p1:WarrantyPeriod>
    <p1:Description>parts and labor</p1:Description>
   </p1:Warranty>
       ...
</PD:Features>

함수를 string() 지정하면 지정된 노드의 문자열 값이 수신됩니다.

SELECT CatalogDescription.query('
declare namespace PD="https://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelDescription";
 string(/PD:ProductDescription[1]/PD:Features[1])
')
FROM Production.ProductModel
WHERE ProductModelID = 19;

다음은 부분 결과입니다.

These are the product highlights.
3 yearsparts and labor...

B. 다양한 노드에서 문자열 함수 사용

다음 예에서는 XML 인스턴스가 xml 유형의 변수에 할당됩니다. 쿼리는 다양한 노드에 적용 string() 한 결과를 설명하기 위해 지정됩니다.

DECLARE @x AS XML;

SET @x = '<?xml version="1.0" encoding="UTF-8" ?>
<!--  This is a comment -->
<root>
  <a>10</a>
just text
  <b attr="x">20</b>
</root>
';

다음 쿼리는 문서 노드의 문자열 값을 검색합니다. 이 값은 모든 하위 텍스트 노드의 문자열 값을 연결하여 형성됩니다.

SELECT @x.query('string(/)');

결과는 다음과 같습니다.

This is a comment 10
just text
 20

다음 쿼리는 처리 명령 노드의 문자열 값을 검색하려고 합니다. 결과는 텍스트 노드가 없기 때문에 빈 시퀀스입니다.

SELECT @x.query('string(/processing-instruction()[1])');

다음 쿼리는 주석 노드의 문자열 값을 검색하고 텍스트 노드를 반환합니다.

SELECT @x.query('string(/comment()[1])');

결과는 다음과 같습니다.

This is a comment