유니코드 문자 형식을 사용하여 데이터 가져오기 및 내보내기
확장/DBCS 문자를 포함하는 데이터 파일을 사용하여 MicrosoftSQL Server의 여러 인스턴스 간에 대량 데이터 전송을 수행하는 경우에는 유니코드 문자 형식을 사용하는 것이 좋습니다. 유니코드 문자 데이터 형식을 사용하면 작업을 수행 중인 클라이언트에서 사용되는 코드 페이지와 다른 코드 페이지를 사용하여 서버에서 데이터를 내보낼 수 있습니다. 이런 경우 유니코드 문자 형식을 사용하면 다음과 같은 이점이 있습니다.
원본 및 대상 데이터가 유니코드 데이터 형식이면 유니코드 문자 형식을 사용하여 모든 문자 데이터를 보존할 수 있습니다.
원본 및 대상 데이터가 유니코드 데이터 형식이 아니면 유니코드 문자 형식을 사용하여 원본 데이터에 있지만 대상에서 표현할 수 없는 확장 문자의 손실을 최소화할 수 있습니다.
유니코드 문자 형식 데이터 파일은 유니코드 파일의 규칙을 따릅니다. 파일의 처음 두 바이트는 16진수 0xFFFE입니다. 이 두 바이트는 바이트 순서 표시로서 제공되며 높은 순서 바이트가 파일의 처음에 저장될지 마지막에 저장될지를 지정합니다.
중요 |
---|
유니코드 문자 데이터 파일에 서식 파일을 사용하려면 모든 입력 필드가 유니코드 텍스트 문자열(고정 크기 또는 문자 종료 유니코드 문자열)이어야 합니다. |
유니코드 문자 형식 데이터 파일에 저장되어 있는 sql_variant 데이터는 데이터가 char 데이터 대신 nchar로 저장된다는 것을 제외하면 문자 형식 데이터 파일과 같은 방식으로 작동합니다. 문자 형식에 대한 자세한 내용은 데이터를 가져오거나 내보낼 때 문자 형식 사용을 참조하십시오.
유니코드 문자 형식으로 제공되는 기본값과 다른 필드 또는 행 종결자를 사용하려면 필드 및 행 종결자 지정을 참조하십시오.
유니코드 문자 형식의 명령 옵션
bcp, BULK INSERT 또는 INSERT ... SELECT * FROM OPENROWSET(BULK...)을 사용하여 유니코드 문자 형식 데이터를 테이블에 가져올 수 있습니다. bcp 명령이나 BULK INSERT 문의 경우 명령줄에서 데이터 형식을 지정할 수 있습니다. INSERT ... SELECT * FROM OPENROWSET(BULK...) 문의 경우 서식 파일에서 데이터 형식을 지정해야 합니다.
다음 명령줄 옵션에서 유니코드 문자 형식을 사용할 수 있습니다.
명령 |
옵션 |
설명 |
---|---|---|
bcp |
-w |
유니코드 문자 형식을 사용합니다. |
BULK INSERT |
DATAFILETYPE ='widechar' |
대량으로 데이터를 가져올 때 유니코드 문자 형식을 사용합니다. |
자세한 내용은 bcp 유틸리티, BULK INSERT(Transact-SQL) 또는 OPENROWSET(Transact-SQL)을 참조하십시오.
[!참고]
서식 파일에서 필드 단위로 서식을 지정할 수도 있습니다. 자세한 내용은 데이터를 가져오거나 내보내기 위한 서식 파일을 참조하십시오.
예
다음 예에서는 bcp를 사용하여 유니코드 문자 데이터에 대한 대량 내보내기를 수행하는 방법과 BULK INSERT를 사용하여 내보낸 데이터에 대한 대량 가져오기를 수행하는 방법을 보여 줍니다.
예제 테이블
이 예에서는 dbo 스키마의 AdventureWorks 예제 데이터베이스에 생성된 myTestUniCharData라는 테이블이 필요하며 예를 실행하려면 이 테이블을 만들어야 합니다. 이 테이블을 만들려면 SQL Server Management Studio 쿼리 편집기에서 다음을 실행합니다.
USE AdventureWorks;
GO
CREATE TABLE myTestUniCharData (
Col1 smallint,
Col2 nvarchar(50),
Col3 nvarchar(50)
);
이 테이블을 채우고 결과 내용을 확인하려면 다음 문을 실행합니다.
INSERT INTO myTestUniCharData(Col1,Col2,Col3)
VALUES(1,'DataField2','DataField3');
INSERT INTO myTestUniCharData(Col1,Col2,Col3)
VALUES(2,'DataField2','DataField3');
GO
SELECT Col1,Col2,Col3 FROM myTestUniCharData
bcp를 사용하여 유니코드 문자 데이터 대량 내보내기
테이블의 데이터를 데이터 파일로 내보내려면 bcp에 out 옵션 및 다음 한정자를 사용합니다.
한정자 |
설명 |
---|---|
-w |
유니코드 문자 형식을 지정합니다. |
-t, |
쉼표(,)를 필드 종결자로 지정합니다.
참고
기본 필드 종결자는 탭 유니코드 문자(\t)입니다. 자세한 내용은 필드 및 행 종결자 지정을 참조하십시오.
|
-T |
bcp 유틸리티가 통합 보안을 사용하는 트러스트된 연결을 통해 SQL Server로 연결되도록 지정합니다. -T가 지정되어 있지 않을 경우 성공적으로 로그인하려면 -U와 -P를 지정해야 합니다. |
다음 예에서는 myTestUniCharData 테이블의 유니코드 문자 형식 데이터를 필드 종결자로 쉼표(,)를 사용하는 새 데이터 파일인 myTestUniCharData-w.Dat로 대량으로 내보냅니다. Microsoft Windows 명령 프롬프트에 다음을 입력합니다.
bcp AdventureWorks..myTestUniCharData out C:\myTestUniCharData-w.Dat -w -t, -T
BULK INSERT를 사용하여 유니코드 문자 데이터 대량 가져오기
다음 예에서는 BULK INSERT를 사용하여 myTestNativeData-n.Dat 데이터 파일의 데이터를 myTestNativeData 테이블로 가져옵니다. 기본 필드 종결자(,)가 아닌 필드 종결자는 문에서 선언해야 합니다. SQL Server Management Studio 쿼리 편집기에서 다음을 실행합니다.
USE AdventureWorks;
GO
BULK INSERT myTestUniCharData
FROM 'C:\myTestUniCharData-w.Dat'
WITH (
DATAFILETYPE='widechar',
FIELDTERMINATOR=','
);
GO
SELECT Col1,Col2,Col3 FROM myTestUniCharData;
GO