XML 서식 파일 이해
Microsoft SQL Server 2005는 XML 서식 파일을 작성하기 위한 구문을 정의하는 XML 스키마를 제공합니다. XML 서식 파일은 XSDL(XML Schema Definition Language)에 정의되어 있는 이 스키마에 충실해야 합니다. XML 서식 파일은 SQL Server 도구를 SQL 네이티브 클라이언트와 함께 설치한 경우에만 지원됩니다.
[!참고] SQL Server 2005는 두 가지 유형의 서식 파일을 지원하지만 Microsoft SQL Server 2000과 이전 버전은 한 가지 유형의 서식 파일만 지원합니다. .XML 서식 파일에서 이전 유형을 구분하기 위해 기존 유형의 서식 파일을 비 XML 서식 파일이라고 합니다.
XML 서식 파일을 사용하여 데이터를 대량으로 테이블이나 파티션이 없는 뷰로 가져오고 내보낼 수 있습니다. XML 서식 파일은 SQL Server 2000 및 이전 버전에서 지원되는 비 XML 서식 파일(SQL Server 2005에서도 계속 지원됨)을 대체합니다. XML 서식 파일은 비 XML 서식 파일보다 더 융통성 있고 강력합니다. XML 서식 파일은 이해하기 쉽고 만들기 쉽습니다. 또한 사람이 읽을 수 있는 형태이기 때문에 대량 작업 중에 데이터가 해석되는 방식을 쉽게 이해할 수 있습니다. XML 인코딩은 데이터 파일의 데이터 형식과 데이터 요소뿐만 아니라 데이터 요소와 테이블 열 간의 매핑도 명확하게 설명합니다.
XML 서식 파일은 이전 버전과의 호환성을 유지하면서 향상될 수 있습니다. 또한 XML 인코딩은 명확하기 때문에 지정된 데이터 파일에 대해 다수의 서식 파일을 쉽게 만들 수 있습니다. 데이터 필드 전체나 일부를 서로 다른 테이블이나 뷰에 매핑해야 하는 경우 이 기능이 유용합니다.
bcp 명령을 사용하면 테이블에 대한 XML 서식 파일을 자동으로 만들 수 있습니다. 자세한 내용은 bcp 유틸리티를 참조하십시오.
XML 서식 파일의 구조
비 XML 서식 파일과 마찬가지로 XML 서식 파일도 데이터 파일의 데이터 필드 형식과 구조를 정의하며 해당 데이터 필드를 단일 대상 테이블의 열에 매핑합니다.
XML 서식 파일에는 두 개의 주요 구성 요소 <RECORD>와 <ROW>가 있습니다.
- <RECORD>는 데이터 파일에 저장되어 있는 데이터를 설명합니다.
각 <RECORD> 요소는 하나 이상의 <FIELD> 요소 집합을 포함합니다. 이러한 요소는 데이터 파일의 필드에 해당합니다. 기본 구문은 다음과 같습니다.
<RECORD>
<FIELD .../> [ ...n ]
</RECORD>
각 <FIELD> 요소는 특정 데이터 필드의 내용을 설명합니다. 필드 하나는 테이블의 열 하나에만 매핑할 수 있지만 모든 필드를 열에 매핑해야 하는 것은 아닙니다.
데이터 파일의 필드는 고정/가변 길이이거나 종료된 문자일 수 있습니다. 필드 값은 문자(1바이트 표현 사용), 와이드 문자(유니코드 2바이트 표현 사용), 네이티브 데이터베이스 형식 또는 파일 이름으로 표현될 수 있습니다. 필드 값이 파일 이름으로 표현되는 경우 파일 이름은 대상 테이블의 BLOB 열 값이 포함된 파일을 가리킵니다. - <ROW>는 파일의 데이터를 SQL Server 테이블로 가져올 때 데이터 파일의 데이터 행을 구성하는 방법을 설명합니다.
<ROW> 요소에는 <COLUMN> 열 집합이 포함됩니다. 이러한 요소는 테이블 열에 해당합니다. 기본 구문은 다음과 같습니다.
<ROW>
<COLUMN .../> [ ...n ]
</ROW>
각 <COLUMN> 요소는 데이터 파일의 필드 하나에만 매핑할 수 있습니다. <ROW> 요소에 있는 <COLUMN> 요소의 순서는 대량 작업에서 요소가 반환되는 순서를 정의합니다. XML 서식 파일은 각 <COLUMN> 요소에 대량 가져오기 작업의 대상 테이블에 있는 열과 관련이 없는 로컬 이름을 할당합니다.
다음 표에서는 이 섹션의 항목에 대해 설명합니다.
항목 | 설명 |
---|---|
XML 서식 파일의 XML 스키마 요소와 특성에 대한 요약을 포함합니다. |
|
Adventure Works 예를 비롯한 다양한 경우에 XML 서식 파일을 사용하는 방법에 대한 정보를 포함합니다. |