이 샘플에서는 대량 복사 함수를 사용하여 서식 파일 없이 기본 모드 데이터 파일을 만드는 방법을 보여 줍니다. 이 샘플은 ODBC 버전 3.0 이상을 위해 개발되었습니다.
중요합니다
가능하면 Windows 인증을 사용하세요. Windows 인증을 사용할 수 없는 경우 런타임에 자격 증명을 입력하라는 메시지를 사용자에게 표시합니다. 파일에 자격 증명을 저장하지 마세요. 자격 증명을 유지해야 하는 경우 Win32 암호화 API를 사용하여 암호화해야 합니다.
서식 파일 없이 대량 복사하려면
환경 핸들 및 연결 핸들을 할당합니다.
대량 복사 작업을 사용하도록 설정하려면 SQL_COPT_SS_BCP 및 SQL_BCP_ON 설정합니다.
SQL Server에 연결합니다.
bcp_init 호출하여 다음 정보를 설정합니다.
대량 복사할 테이블 또는 뷰의 이름입니다.
데이터베이스에 복사할 데이터가 포함되거나 데이터베이스에서 복사할 때 데이터를 수신하는 데이터 파일의 이름입니다.
대량 복사 오류 메시지를 받을 데이터 파일의 이름입니다(메시지 파일을 원하지 않는 경우 NULL 지정).
복사본의 방향: 파일에서 뷰 또는 테이블로 DB_IN 테이블 또는 뷰에서 파일로 DB_OUT.
bcp_exec 호출하여 대량 복사 작업을 실행합니다.
이러한 단계를 사용하여 DB_OUT 설정하면 파일이 네이티브 형식으로 만들어집니다. 그런 다음 DB_OUT DB_IN 대신 설정된다는 점을 제외하고 이러한 동일한 단계를 수행하여 서버에 파일을 대량 복사할 수 있습니다. 원본 테이블과 대상 테이블의 구조가 정확히 동일한 경우에만 작동합니다.
예시
이 샘플은 IA64에서 지원되지 않습니다.
기본 데이터베이스가 AdventureWorks 샘플 데이터베이스인 AdventureWorks라는 ODBC 데이터 원본이 필요합니다. ( Microsoft SQL Server 샘플 및 커뮤니티 프로젝트 홈페이지에서 AdventureWorks 샘플 데이터베이스를 다운로드할 수 있습니다.) 이 데이터 원본은 운영 체제에서 제공하는 ODBC 드라이버를 기반으로 해야 합니다(드라이버 이름은 "SQL Server"). 이 샘플을 64비트 운영 체제에서 32비트 애플리케이션으로 빌드하고 실행하는 경우 %windir%\SysWOW64\odbcad32.exeODBC 관리자를 사용하여 ODBC 데이터 원본을 만들어야 합니다.
이 샘플은 컴퓨터의 기본 SQL Server 인스턴스에 연결합니다. 명명된 인스턴스에 연결하려면 ODBC 데이터 원본의 정의를 변경하여 서버\namedinstance 형식을 사용하여 인스턴스를 지정합니다. 기본적으로 SQL Server Express는 명명된 인스턴스에 설치됩니다.
odbc32.lib 및 odbcbcp.lib를 사용하여 컴파일합니다.
// compile with: odbc32.lib odbcbcp.lib
#include <stdio.h>
#include <string.h>
#include <windows.h>
#include <sql.h>
#include <sqlext.h>
#include <odbcss.h>
#define MAXBUFLEN 256
SQLHENV henv = SQL_NULL_HENV;
HDBC hdbc1 = SQL_NULL_HDBC;
void Cleanup() {
if (hdbc1 != SQL_NULL_HDBC) {
SQLDisconnect(hdbc1);
SQLFreeHandle(SQL_HANDLE_DBC, hdbc1);
}
if (henv != SQL_NULL_HENV)
SQLFreeHandle(SQL_HANDLE_ENV, henv);
}
int main() {
RETCODE retcode;
// Bulk copy variables.
SDWORD cRows;
// Allocate the ODBC environment and save handle.
retcode = SQLAllocHandle (SQL_HANDLE_ENV, NULL, &henv);
if ( (retcode != SQL_SUCCESS_WITH_INFO) && (retcode != SQL_SUCCESS)) {
printf("SQLAllocHandle(Env) Failed\n\n");
Cleanup();
return(9);
}
// Notify ODBC that this is an ODBC 3.0 app.
retcode = SQLSetEnvAttr(henv, SQL_ATTR_ODBC_VERSION, (SQLPOINTER) SQL_OV_ODBC3, SQL_IS_INTEGER);
if ( (retcode != SQL_SUCCESS_WITH_INFO) && (retcode != SQL_SUCCESS)) {
printf("SQLSetEnvAttr(ODBC version) Failed\n\n");
Cleanup();
return(9);
}
// Allocate ODBC connection handle, set bulk copy mode, and then connect.
retcode = SQLAllocHandle(SQL_HANDLE_DBC, henv, &hdbc1);
if ( (retcode != SQL_SUCCESS_WITH_INFO) && (retcode != SQL_SUCCESS)) {
printf("SQLAllocHandle(hdbc1) Failed\n\n");
Cleanup();
return(9);
}
retcode = SQLSetConnectAttr(hdbc1, SQL_COPT_SS_BCP, (void *)SQL_BCP_ON, SQL_IS_INTEGER);
if ( (retcode != SQL_SUCCESS_WITH_INFO) && (retcode != SQL_SUCCESS)) {
printf("SQLSetConnectAttr(hdbc1) Failed\n\n");
Cleanup();
return(9);
}
// Sample uses Integrated Security, create the SQL Server DSN using Windows NT authentication.
retcode = SQLConnect(hdbc1, (UCHAR*)"AdventureWorks", SQL_NTS, (UCHAR*)"", SQL_NTS, (UCHAR*)"", SQL_NTS);
if ( (retcode != SQL_SUCCESS) && (retcode != SQL_SUCCESS_WITH_INFO) ) {
printf("SQLConnect() Failed\n\n");
Cleanup();
return(9);
}
// Initialize the bulk copy.
retcode = bcp_init(hdbc1, "Purchasing.Vendor", "BCPODBC.bcp", "BCPERROR.out", DB_OUT);
// Test is for the bulk copy return of SUCCEED, not the ODBC return of SQL_SUCCESS.
if ( (retcode != SUCCEED) ) {
printf("bcp_init(hdbc1) Failed\n\n");
Cleanup();
return(9);
}
// Execute the bulk copy.
retcode = bcp_exec(hdbc1, &cRows);
if ( (retcode != SUCCEED) ) {
printf("bcp_exec(hdbc1) Failed\n\n");
Cleanup();
return(9);
}
printf("Number of rows bulk copied out = %d.\n", cRows);
// Cleanup
SQLDisconnect(hdbc1);
SQLFreeHandle(SQL_HANDLE_DBC, hdbc1);
SQLFreeHandle(SQL_HANDLE_ENV, henv);
}