반환된 XML 모양 지정에서 AUTO 모드 추론

적용 대상: SQL Server Azure SQL Database Azure Synapse Analytics 병렬 데이터 웨어하우스

AUTO 모드는 쿼리를 기반으로 반환된 XML의 모양을 결정합니다. 요소 중첩 방법을 결정할 때 AUTO 모드 추론은 인접한 행의 열 값을 비교합니다. ntext, text, imagexml 을 제외한 모든 유형의 열이 비교됩니다. (n)varchar(max)varbinary(max) 유형의 열이 비교됩니다.

다음 예에서는 결과 XML의 모양을 결정하는 AUTO 모드 추론에 대해 설명합니다.

SELECT T1.Id, T2.Id, T1.Name  
FROM   T1, T2  
WHERE ...  
ORDER BY T1.Id
FOR XML AUTO;

테이블 T1의 키가 지정되지 않은 경우 새로운 <T1> 요소가 시작되는 위치를 확인하기 위해 ntext, text, imagexml 을 제외한 T1의 모든 열 값이 비교됩니다. 그런 다음 Name 열이 nvarchar(40) 이고 SELECT 문이 이 행 집합을 반환한다고 가정합니다.

T1.Id  T1.Name  T2.Id  
-----------------------  
1       Andrew    2  
1       Andrew    3  
1       Nancy     4  

AUTO 모드 추론은 테이블 T1, Id 및 Name 열의 모든 값을 비교합니다. 처음 두 행은 Id 및 Name 열에 대한 값이 같기 때문에 두 개의 <T2> 자식 요소가 포함된 하나의 <T1> 요소가 결과에 추가됩니다.

다음은 반환되는 XML입니다.

<T1 Id="1" Name="Andrew">  
    <T2 Id="2" />  
    <T2 Id="3" />  
</T1>  
<T1 Id="1" Name="Nancy" >  
      <T2 Id="4" />  
</T>  

이제 Name 열이 text 유형이라고 가정해 보십시오. AUTO 모드 추론은 이 유형의 값을 비교하지 않습니다. 그 대신 값이 같지 않다고 가정합니다. 그 결과 다음과 같이 XML이 생성됩니다.

<T1 Id="1" Name="Andrew" >  
  <T2 Id="2" />  
</T1>  
<T1 Id="1" Name="Andrew" >  
  <T2 Id="3" />  
</T1>  
<T1 Id="1" Name="Nancy" >  
  <T2 Id="4" />  
</T1>  

참고 항목

FOR XML에서 AUTO 모드 사용