SQL Server Native Client에서 연결 문자열 키워드 사용
일부 SQL Server Native Client API에서는 연결 문자열을 사용하여 연결 특성을 지정합니다. 연결 문자열은 키워드와 연관된 값의 목록이며 각 키워드는 특정 연결 특성을 식별합니다.
[!참고]
SQL Server Native Client는 이전 버전과의 호환성을 유지하기 위해 연결 문자열에서 모호성을 허용합니다. 예를 들어 일부 키워드를 여러 번 지정할 수 있으며 위치나 우선 순위에 따라 충돌하는 키워드를 해결할 수 있습니다. 이후 버전의 SQL Server Native Client에서는 연결 문자열의 모호성을 허용하지 않을 수도 있습니다. SQL Server Native Client를 사용하도록 응용 프로그램을 수정하는 경우 연결 문자열 모호성에 대한 종속성을 제거하는 것이 좋습니다.
다음 섹션에서는 SQL Server Native Client를 데이터 공급자로 사용할 때 SQL Server Native Client OLE DB 공급자, SQL Server Native Client ODBC 드라이버 및 ADO(ActiveX Data Objects)와 함께 사용할 수 있는 키워드를 설명합니다.
OLE DB 공급자 연결 문자열 키워드
OLE DB 응용 프로그램에서는 데이터 원본 개체를 다음 두 가지 방법으로 초기화할 수 있습니다.
IDBInitialize::Initialize
IDataInitialize::GetDataSource
첫 번째 경우에는 DBPROPSET_DBINIT 속성 집합의 DBPROP_INIT_PROVIDERSTRING 속성을 설정하는 방법을 통해 공급자 문자열을 사용하여 연결 속성을 초기화할 수 있습니다. 두 번째 경우에는 초기화 문자열을 IDataInitialize::GetDataSource 메서드에 전달하여 연결 속성을 초기화할 수 있습니다. 두 방법 모두 동일한 OLE DB 연결 속성을 초기화하지만 서로 다른 키워드 집합을 사용합니다. IDataInitialize::GetDataSource에서 사용되는 키워드 집합은 적어도 초기화 속성 그룹 내의 속성에 대한 설명입니다.
해당 OLE DB 속성이 기본값 또는 OLE DB 속성 값으로 명시적으로 설정된 공급자 문자열 설정에서 공급자 문자열의 설정을 재정의합니다.
공급자 문자열에서 DBPROP_INIT_PROVIDERSTRING 값을 통해 설정되는 부울 속성은 "yes" 및 "no" 값을 사용하여 설정됩니다. 초기화 문자열에서 IDataInitialize::GetDataSource를 사용하여 설정되는 부울 속성은 "true" 및 "false" 값을 사용하여 설정됩니다.
IDataInitialize::GetDataSource를 사용하는 응용 프로그램에서는 IDBInitialize::Initialize에 사용되는 키워드도 사용할 수 있지만 이러한 키워드는 기본값이 없는 속성에서만 사용할 수 있습니다. 응용 프로그램이 초기화 문자열에서 IDataInitialize::GetDataSource 키워드와 IDBInitialize::Initialize 키워드를 모두 사용하는 경우에는 IDataInitialize::GetDataSource 키워드 설정이 사용됩니다. IDataInitialize:GetDataSource 연결 문자열에서 IDBInitialize::Initialize 키워드를 사용할 수 있는 동작은 이후 버전에서 유지되지 않을 수 있으므로 응용 프로그램에서 이와 같이 사용하지 않는 것이 좋습니다.
[!참고]
IDataInitialize::GetDataSource를 통해 전달된 연결 문자열은 속성으로 변환된 후 IDBProperties::SetProperties를 통해 적용됩니다. 구성 요소 서비스가 IDBProperties::GetPropertyInfo에서 속성 설명을 찾으면 해당 속성이 독립 실행형 속성으로 적용됩니다. 그렇지 않으면 DBPROP_PROVIDERSTRING 속성을 통해 속성이 적용됩니다. 예를 들어 연결 문자열을 Data Source=server1;Server=server2로 지정하면 Data Source는 속성으로 설정되지만 Server가 공급자 문자열로 전달됩니다.
같은 공급자별 속성의 인스턴스를 여러 개 지정하면 첫 번째 속성의 첫 번째 값이 사용됩니다.
IDBInitialize::Initialize에 DBPROP_INIT_PROVIDERSTRING을 지정하는 OLE DB 응용 프로그램에서 사용하는 연결 문자열의 구문은 다음과 같습니다.
connection-string ::= empty-string[;] | attribute[;] | attribute; connection-string
empty-string ::=
attribute ::= attribute-keyword=[{]attribute-value[}]
attribute-value ::= character-string
attribute-keyword ::= identifier
특성 값을 중괄호로 묶을 수도 있으며, 그렇게 하는 것이 좋습니다. 그러면 특성 값에 영숫자가 아닌 문자가 있을 경우 발생할 수 있는 문제를 막을 수 있습니다. 값에서 첫 번째 닫는 중괄호는 값을 종결하는 문자로 간주되므로 값에 닫는 중괄호가 있어서는 안 됩니다.
연결 문자열 키워드에서 등호(=) 다음에 나오는 공백 문자는 값을 따옴표로 묶은 경우에도 리터럴로 해석됩니다.
다음 표에서는 DBPROP_INIT_PROVIDERSTRING에서 사용할 수 있는 키워드에 대해 설명합니다.
키워드 |
초기화 속성 |
설명 |
---|---|---|
Addr |
SSPROP_INIT_NETWORKADDRESS |
"Address"에 대한 동의어입니다. |
Address |
SSPROP_INIT_NETWORKADDRESS |
조직의 SQL Server 인스턴스 네트워크 주소입니다. 유효한 주소 구문에 대한 자세한 내용은 이 항목의 뒷부분에 있는 Address ODBC 키워드에 대한 설명을 참조하십시오. |
APP |
SSPROP_INIT_APPNAME |
응용 프로그램을 식별하는 문자열입니다. |
AttachDBFileName |
SSPROP_INIT_FILENAME |
연결할 수 있는 데이터베이스의 전체 경로 이름을 포함한 주 파일의 이름입니다. AttachDBFileName을 사용하려면 공급자 문자열 Database 키워드에도 데이터베이스 이름을 지정해야 합니다. 데이터베이스가 이전에 연결된 경우 SQL Server에서는 이 데이터베이스를 다시 연결하지 않으며 연결된 데이터베이스를 연결 기본값으로 사용합니다. |
Auto Translate |
SSPROP_INIT_AUTOTRANSLATE |
"AutoTranslate"에 대한 동의어입니다. |
AutoTranslate |
SSPROP_INIT_AUTOTRANSLATE |
OEM/ANSI 문자 변환을 구성합니다. 인식되는 값은 "yes" 및 "no"입니다. |
Database |
DBPROP_INIT_CATALOG |
데이터베이스 이름입니다. |
DataTypeCompatibility |
SSPROP_INIT_DATATYPECOMPATIBILITY |
사용할 데이터 형식 처리 모드를 지정합니다. 인식되는 값은 "0"(공급자 데이터 형식) 및 "80"(SQL Server 2000 데이터 형식)입니다. |
Encrypt |
SSPROP_INIT_ENCRYPT |
데이터를 네트워크를 통해 보내기 전에 암호화해야 하는지 여부를 지정합니다. 가능한 값은 "yes" 및 "no"입니다. 기본값은 "no"입니다. |
FailoverPartner |
SSPROP_INIT_FAILOVERPARTNER |
데이터베이스 미러링에 사용되는 장애 조치(Failover) 서버의 이름입니다. |
FailoverPartnerSPN |
SSPROP_INIT_FAILOVERPARTNERSPN |
장애 조치(Failover) 파트너의 SPN입니다. 기본값은 빈 문자열입니다. 빈 문자열을 지정하면 SQL Server Native Client는 공급자가 생성한 기본 SPN을 사용합니다. |
Language |
SSPROPT_INIT_CURRENTLANGUAGE |
SQL Server 언어입니다. |
MarsConn |
SSPROP_INIT_MARSCONNECTION |
서버가 SQL Server 2005 이상 버전인 경우 연결에서 MARS(Multiple Active Result Sets)를 설정하거나 해제합니다. 가능한 값은 "yes" 및 "no"입니다. 기본값은 "no"입니다. |
Net |
SSPROP_INIT_NETWORKLIBRARY |
"Network"에 대한 동의어입니다. |
Network |
SSPROP_INIT_NETWORKLIBRARY |
조직의 SQL Server 인스턴스에 연결하는 데 사용하는 네트워크 라이브러리입니다. |
Network Library |
SSPROP_INIT_NETWORKLIBRARY |
"Network"에 대한 동의어입니다. |
PacketSize |
SSPROP_INIT_PACKETSIZE |
네트워크 패킷 크기입니다. 기본값은 0이며 이는 서버가 sp_configure 'network packet size' 설정을 기반으로 패킷 크기를 구성함을 의미합니다. |
PersistSensitive |
DBPROP_AUTH_PERSIST_SENSITIVE_AUTHINFO |
문자열 "yes" 및 "no"를 값으로 받습니다. "no"인 경우 중요한 인증 정보를 데이터 원본 개체에 유지할 수 없습니다. |
PWD |
DBPROP_AUTH_PASSWORD |
SQL Server 로그인 암호입니다. |
Server |
DBPROP_INIT_DATASOURCE |
조직의 SQL Server 인스턴스 이름입니다. 지정하지 않으면 로컬 컴퓨터의 기본 인스턴스에 연결합니다. 유효한 주소 구문에 대한 자세한 내용은 이 항목에 있는 Server ODBC 키워드에 대한 설명을 참조하십시오. |
ServerSPN |
SSPROP_INIT_SERVERSPN |
서버의 SPN입니다. 기본값은 빈 문자열입니다. 빈 문자열을 지정하면 SQL Server Native Client는 공급자가 생성한 기본 SPN을 사용합니다. |
Timeout |
DBPROP_INIT_TIMEOUT |
데이터 원본 초기화가 완료될 때까지 기다릴 시간(초)입니다. |
Trusted_Connection |
DBPROP_AUTH_INTEGRATED |
"yes"인 경우 SQL Server Native Client OLE DB 공급자가 Windows 인증 모드를 사용하여 로그인 유효성을 검사하도록 지시합니다. 그렇지 않으면 SQL Server Native Client OLE DB 공급자가 SQL Server 사용자 이름과 암호를 사용하여 로그인 유효성을 검사하도록 지시하므로 UID 및 PWD 키워드를 지정해야 합니다. |
TrustServerCertificate |
SSPROP_INIT_TRUST_SERVER_CERTIFICATE |
문자열 "yes" 및 "no"를 값으로 받습니다. 기본값은 "no"이며 서버 인증서의 유효성을 검사하는 것을 의미합니다. |
UID |
DBPROP_AUTH_USERID |
SQL Server 로그인 이름입니다. |
UseProcForPrepare |
SSPROP_INIT_USEPROCFORPREP |
이 키워드는 더 이상 사용되지 않으며 SQL Server Native Client OLE DB 공급자는 이 설정을 무시합니다. |
WSID |
SSPROP_INIT_WSID |
워크스테이션 식별자입니다. |
IDataInitialize::GetDataSource를 사용하는 OLE DB 응용 프로그램에서 사용하는 연결 문자열의 구문은 다음과 같습니다.
connection-string ::= empty-string[;] | attribute[;] | attribute; connection-string
empty-string ::=
attribute ::= attribute-keyword=[quote]attribute-value[quote]
attribute-value ::= character-string
attribute-keyword ::= identifier
quote ::= " | '
속성 사용은 해당 범위에 허용되는 구문을 따라야 합니다. 예를 들어 WSID는 따옴표 대신 중괄호({})를 사용하고 Application Name은 작은따옴표(') 또는 큰따옴표(")를 사용합니다. 문자열 속성만 따옴표로 묶을 수 있습니다. 정수나 열거 속성을 따옴표로 묶으면 "연결 문자열이 OLE DB 사양을 따르지 않습니다." 오류가 발생합니다.
특성 값을 작은따옴표나 큰따옴표로 묶을 수 있으며 그렇게 하는 것이 좋습니다. 그러면 값에 영숫자가 아닌 문자가 있을 경우 발생할 수 있는 문제를 막을 수 있습니다. 큰따옴표를 사용할 경우 값에 큰따옴표를 포함해도 됩니다.
연결 문자열 키워드에서 등호(=) 다음에 나오는 공백 문자는 값을 따옴표로 묶은 경우에도 리터럴로 해석됩니다.
연결 문자열에 다음과 같은 속성이 두 개 이상 있으면 마지막 속성의 값이 사용됩니다.
다음 표에서는 IDataInitialize::GetDataSource에서 사용할 수 있는 키워드에 대해 설명합니다.
키워드 |
초기화 속성 |
설명 |
---|---|---|
Application Name |
SSPROP_INIT_APPNAME |
응용 프로그램을 식별하는 문자열입니다. |
Auto Translate |
SSPROP_INIT_AUTOTRANSLATE |
"AutoTranslate"에 대한 동의어입니다. |
AutoTranslate |
SSPROP_INIT_AUTOTRANSLATE |
OEM/ANSI 문자 변환을 구성합니다. 인식되는 값은 "true"와 "false"입니다. |
Connect Timeout |
DBPROP_INIT_TIMEOUT |
데이터 원본 초기화가 완료될 때까지 기다릴 시간(초)입니다. |
Current Language |
SSPROPT_INIT_CURRENTLANGUAGE |
SQL Server 언어 이름입니다. |
Data Source |
DBPROP_INIT_DATASOURCE |
조직의 SQL Server 인스턴스 이름입니다. 지정하지 않으면 로컬 컴퓨터의 기본 인스턴스에 연결합니다. 유효한 주소 구문에 대한 자세한 내용은 이 항목의 뒷부분에 있는 Server ODBC 키워드에 대한 설명을 참조하십시오. |
DataTypeCompatibility |
SSPROP_INIT_DATATYPECOMPATIBILITY |
사용할 데이터 형식 처리 모드를 지정합니다. 인식되는 값은 "0"(공급자 데이터 형식) 및 "80"(SQL Server 2000 데이터 형식)입니다. |
Failover Partner |
SSPROP_INIT_FAILOVERPARTNER |
데이터베이스 미러링에 사용되는 장애 조치(Failover) 서버의 이름입니다. |
Failover Partner SPN |
SSPROP_INIT_FAILOVERPARTNERSPN |
장애 조치(Failover) 파트너의 SPN입니다. 기본값은 빈 문자열입니다. 빈 문자열을 지정하면 SQL Server Native Client는 공급자가 생성한 기본 SPN을 사용합니다. |
Initial Catalog |
DBPROP_INIT_CATALOG |
데이터베이스 이름입니다. |
Initial File Name |
SSPROP_INIT_FILENAME |
연결할 수 있는 데이터베이스의 전체 경로 이름을 포함한 주 파일의 이름입니다. AttachDBFileName을 사용하려면 공급자 문자열 DATABASE 키워드에도 데이터베이스 이름을 지정해야 합니다. 데이터베이스가 이전에 연결된 경우 SQL Server에서는 이 데이터베이스를 다시 연결하지 않으며 연결된 데이터베이스를 연결 기본값으로 사용합니다. |
Integrated Security |
DBPROP_AUTH_INTEGRATED |
Windows 인증을 위해 "SSPI" 값을 적용합니다. |
MARS Connection |
SSPROP_INIT_MARSCONNECTION |
서버가 SQL Server 2005 또는 SQL Server 2008인 경우 연결에서 MARS(Multiple Active Result Sets)를 설정하거나 해제합니다. 인식되는 값은 "true"와 "false"입니다. 기본값은 "false"입니다. |
Network Address |
SSPROP_INIT_NETWORKADDRESS |
조직의 SQL Server 인스턴스 네트워크 주소입니다. 유효한 주소 구문에 대한 자세한 내용은 이 항목의 뒷부분에 있는 Address ODBC 키워드에 대한 설명을 참조하십시오. |
Network Library |
SSPROP_INIT_NETWORKLIBRARY |
조직의 SQL Server 인스턴스에 연결하는 데 사용하는 네트워크 라이브러리입니다. |
Packet Size |
SSPROP_INIT_PACKETSIZE |
네트워크 패킷 크기입니다. 기본값은 0이며 이는 서버가 sp_configure 'network packet size' 설정을 기반으로 패킷 크기를 구성함을 의미합니다. |
Password |
DBPROP_AUTH_PASSWORD |
SQL Server 로그인 암호입니다. |
Persist Security Info |
DBPROP_AUTH_PERSIST_SENSITIVE_AUTHINFO |
문자열 "true" 및 "false"를 값으로 받습니다. "false"인 경우 중요한 인증 정보를 데이터 원본 개체에 유지할 수 없습니다. |
Provider |
|
SQL Server Native Client의 경우 "SQLNCLI10"이어야 합니다. |
Server SPN |
SSPROP_INIT_SERVERSPN |
서버의 SPN입니다. 기본값은 빈 문자열입니다. 빈 문자열을 지정하면 SQL Server Native Client는 공급자가 생성한 기본 SPN을 사용합니다. |
Trust Server Certificate |
SSPROP_INIT_TRUST_SERVER_CERTIFICATE |
문자열 "true" 및 "false"를 값으로 받습니다. 기본값은 "false"이며 서버 인증서의 유효성을 검사하는 것을 의미합니다. |
Use Encryption for Data |
SSPROP_INIT_ENCRYPT |
데이터를 네트워크를 통해 보내기 전에 암호화해야 하는지 여부를 지정합니다. 가능한 값은 "true" 및 "false"입니다. 기본값은 "false"입니다. |
User ID |
DBPROP_AUTH_USERID |
SQL Server 로그인 이름입니다. |
Workstation ID |
SSPROP_INIT_WSID |
워크스테이션 식별자입니다. |
참고 연결 문자열에서 "이전 암호" 속성은 공급자 문자열 속성을 통해 사용할 수 없는 현재(만료된) 암호인 SSPROP_AUTH_OLD_PASSWORD를 설정합니다.
ODBC 드라이버 연결 문자열 키워드
ODBC 응용 프로그램에서는 연결 문자열을 SQLDriverConnect 및 SQLBrowseConnect 함수에 대한 매개 변수로 사용합니다.
ODBC에서 사용하는 연결 문자열의 구문은 다음과 같습니다.
connection-string ::= empty-string[;] | attribute[;] | attribute; connection-string
empty-string ::=
attribute ::= attribute-keyword=[{]attribute-value[}]
attribute-value ::= character-string
attribute-keyword ::= identifier
특성 값을 중괄호로 묶을 수도 있으며, 그렇게 하는 것이 좋습니다. 그러면 특성 값에 영숫자가 아닌 문자가 있을 경우 발생할 수 있는 문제를 막을 수 있습니다. 값에서 첫 번째 닫는 중괄호는 값을 종결하는 문자로 간주되므로 값에 닫는 중괄호가 있어서는 안 됩니다.
다음 표에서는 ODBC 연결 문자열에서 사용할 수 있는 키워드에 대해 설명합니다.
키워드 |
설명 |
---|---|
Addr |
"Address"에 대한 동의어입니다. |
Address |
SQL Server 인스턴스를 실행하는 서버의 네트워크 주소입니다. Address는 일반적으로 서버의 네트워크 이름이지만 파이프, IP 주소나 TCP/IP 포트 및 소켓 주소와 같은 다른 이름일 수도 있습니다. IP 주소를 지정하는 경우 SQL Server 구성 관리자에서 TCP/IP 또는 명명된 파이프 프로토콜이 설정되어 있는지 확인합니다. SQL Server Native Client를 사용할 때 ODBC 연결 문자열에서 Address 값이 Server에 전달된 값보다 우선합니다. 또한 Address=;이면 Server 키워드에 지정된 서버에 연결하지만 Address= ;, Address=.;, Address=localhost; 및 Address=(local);이면 항상 로컬 서버에 연결합니다. Address 키워드에 대한 전체 구문은 다음과 같습니다. [protocol:]Address[,port |\pipe\pipename] protocol은 tcp(TCP/IP), lpc(shared memory) 또는 np(named pipes)일 수 있습니다. 프로토콜에 대한 자세한 내용은 네트워크 프로토콜 선택을 참조하십시오. protocol 또는 Network 키워드가 지정되지 않은 경우 SQL Server Native Client는 SQL Server 구성 관리자에 지정된 프로토콜 순서를 사용합니다. port는 지정한 서버에서 연결할 포트입니다. 기본적으로 SQL Server는 포트 1433을 사용합니다. 프로토콜에 대한 자세한 내용은 네트워크 프로토콜 선택을 참조하십시오. |
AnsiNPW |
"yes"인 경우 드라이버는 NULL 비교, 문자 데이터 패딩, 경고 및 NULL 연결 처리에 ANSI 정의 동작을 사용합니다. "no"인 경우 ANSI 정의 동작이 표시되지 않습니다. ANSI NPW 동작에 대한 자세한 내용은 ISO 옵션의 효과를 참조하십시오. |
APP |
SQLDriverConnect를 호출하는 응용 프로그램의 이름입니다(옵션). 지정된 경우 이 값은 master.dbo.sysprocesses의 program_name 열에 저장되며 sp_who 및 APP_NAME 함수에서 반환됩니다. |
AttachDBFileName |
연결할 수 있는 데이터베이스에 대한 주 파일의 이름입니다. 전체 경로를 포함하여 C 문자열 변수를 사용할 경우 다음과 같이 모든 \ 문자를 이스케이프합니다. AttachDBFileName=c:\\MyFolder\\MyDB.mdf 이 데이터베이스는 연결되어 해당 연결에 대한 기본 데이터베이스가 됩니다. AttachDBFileName을 사용하려면 SQLDriverConnect DATABASE 매개 변수 또는 SQL_COPT_CURRENT_CATALOG 연결 특성에도 데이터베이스 이름을 지정해야 합니다. 데이터베이스가 이전에 연결된 경우 SQL Server에서는 이 데이터베이스를 다시 연결하지 않으며 연결된 데이터베이스를 연결 기본값으로 사용합니다. |
AutoTranslate |
"yes"인 경우 클라이언트와 서버 간에 전송된 ANSI 문자열을 유니코드를 통한 변환으로 변환하여 클라이언트와 서버 코드 페이지 간의 확장 문자 일치에서 문제를 최소화합니다. SQL Server char, varchar 또는 text 변수, 매개 변수 또는 열에 전송된 클라이언트 SQL_C_CHAR 데이터는 클라이언트 ACP(ANSI 코드 페이지)를 사용하여 문자에서 유니코드로 변환된 후 서버의 ACP를 사용하여 유니코드에서 문자로 변환됩니다. 클라이언트 SQL_C_CHAR 변수로 전송된 SQL Serverchar, varchar 또는 text 데이터는 서버 ACP를 사용하여 문자에서 유니코드로 변환된 후 클라이언트 ACP를 사용하여 유니코드에서 문자로 변환됩니다. 이러한 변환은 SQL Server Native Client ODBC 드라이버에 의해 클라이언트에서 수행됩니다. 이를 위해서는 서버에 사용된 것과 동일한 ACP(ANSI 코드 페이지)를 클라이언트에서 사용할 수 있어야 합니다. 이러한 설정은 다음 전송에 대해 발생하는 변환에는 영향을 미치지 않습니다.
"no"인 경우 문자 변환이 수행되지 않습니다. SQL Server Native Client ODBC 드라이버는 서버의 char, varchar 또는 text 변수, 매개 변수 또는 열로 전송된 클라이언트 ANSI 문자 SQL_C_CHAR 데이터를 변환하지 않습니다. 서버에서 클라이언트의 SQL_C_CHAR 변수로 전송된 char, varchar 또는 text 데이터에 대해 변환이 수행되지 않습니다. 클라이언트와 SQL Server가 서로 다른 ACP를 사용하는 경우 확장 문자가 잘못 해석될 수 있습니다. |
Database |
연결에 사용되는 기본 SQL Server 데이터베이스의 이름입니다. Database를 지정하지 않으면 로그인에 대해 정의된 기본 데이터베이스가 사용됩니다. ODBC 데이터 원본의 기본 데이터베이스가 로그인에 지정된 기본 데이터베이스를 재지정합니다. AttachDBFileName도 지정하는 경우 외에는 이 데이터베이스는 기존 데이터베이스여야 합니다. AttachDBFileName도 지정하는 경우 여기서 가리키는 주 파일이 연결되고 Database에 지정된 데이터베이스 이름이 제공됩니다. |
Driver |
SQLDrivers에서 반환하는 드라이버의 이름입니다. SQL Server Native Client ODBC 드라이버의 키워드 값은 "{SQL Server Native Client 10.0}"입니다. Driver를 지정하고 DriverCompletion을 SQL_DRIVER_NOPROMPT로 설정하는 경우에는 Server 키워드가 필요합니다. 드라이버 이름에 대한 자세한 내용은 SQL Server Native Client 헤더 및 라이브러리 파일 사용을 참조하십시오. |
DSN |
기존 ODBC 사용자 또는 시스템 데이터 원본의 이름입니다. 이 키워드는 Server, Network 및 Address 키워드에 지정되어 있을 수 있는 모든 값을 재정의합니다. |
Encrypt |
데이터를 네트워크를 통해 보내기 전에 암호화해야 하는지 여부를 지정합니다. 가능한 값은 "yes" 및 "no"입니다. 기본값은 "no"입니다. |
Fallback |
이 키워드는 더 이상 사용되지 않으며 SQL Server Native Client ODBC 드라이버는 이 설정을 무시합니다. |
Failover_Partner |
주 서버에 연결할 수 없는 경우 사용할 장애 조치(Failover) 파트너 서버의 이름입니다. |
FailoverPartnerSPN |
장애 조치(Failover) 파트너의 SPN입니다. 기본값은 빈 문자열입니다. 빈 문자열을 지정하면 SQL Server Native Client는 드라이버가 생성한 기본 SPN을 사용합니다. |
FileDSN |
기존 ODBC 파일 데이터 원본의 이름입니다. |
Language |
SQL Server 언어 이름입니다(옵션). SQL Server에서는 여러 언어에 대한 메시지를 sysmessages에 저장할 수 있습니다. 여러 언어로 SQL Server에 연결할 경우 Language는 연결에 사용할 메시지 집합을 지정합니다. |
MARS_Connection |
서버가 SQL Server 2005 또는 SQL Server 2008인 경우 연결에서 MARS(Multiple Active Result Sets)를 설정하거나 해제합니다. 인식되는 값은 "yes" 및 "no"입니다. 기본값은 "no"입니다. |
Net |
"Network"에 대한 동의어입니다. |
Network |
유효한 값은 dbnmpntw(명명된 파이프)와 dbmssocn(TCP/IP)입니다. 네트워크 프로토콜에 대한 자세한 내용은 네트워크 프로토콜 선택을 참조하십시오. Network 키워드에 대한 값과 Server 키워드에 대한 프로토콜 접두사를 둘 다 지정하면 오류가 발생합니다. |
PWD |
UID 매개 변수에 지정한 SQL Server 로그인 계정의 암호입니다. 로그인 암호가 NULL이거나 Windows 인증을 사용하는 경우(Trusted_Connection = yes) PWD를 지정할 필요가 없습니다. |
QueryLog_On |
"yes"인 경우 연결에서 장기 실행 쿼리 데이터 기록이 사용됩니다. "no"인 경우 장기 실행 쿼리 데이터가 기록되지 않습니다. |
QueryLogFile |
장기 실행 쿼리의 데이터를 기록하는 데 사용할 파일의 전체 경로 및 파일 이름입니다. |
QueryLogTime |
장기 실행 쿼리 기록을 위한 임계값(밀리초)을 지정하는 숫자 문자열입니다. 지정된 시간 내에 응답을 받지 못한 쿼리가 장기 실행 쿼리 로그 파일에 기록됩니다. |
QuotedId |
"yes"인 경우 QUOTED_IDENTIFIERS가 연결에 대해 ON으로 설정되고 SQL Server는 SQL 문에서 ISO 규칙에 따라 따옴표를 사용합니다. "no"인 경우 QUOTED_IDENTIFIERS가 연결에 대해 OFF로 설정되고 SQL Server는 SQL 문에서 레거시 Transact-SQL 규칙에 따라 따옴표를 사용합니다. 자세한 내용은 ISO 옵션의 효과를 참조하십시오. |
Regional |
"yes"인 경우 SQL Server Native Client ODBC 드라이버는 통화, 날짜 및 시간 데이터를 문자 데이터로 변환할 때 클라이언트 설정을 사용합니다. 변환이 한쪽 방향으로만 이루어지므로 드라이버는 INSERT 또는 UPDATE 문에 사용된 매개 변수 등에서 ODBC 표준 형식이 아닌 날짜 문자열이나 통화 값을 인식하지 못합니다. "no"인 경우 드라이버는 ODBC 표준 문자열을 사용하여 문자열로 변환된 통화, 날짜 및 시간을 나타냅니다. |
SaveFile |
연결에 성공하면 현재 연결에 대한 특성이 저장되는 ODBC 데이터 원본 파일의 이름입니다. |
Server |
SQL Server 인스턴스의 이름입니다. 이 값은 네트워크의 서버 이름(IP 주소)이거나 SQL Server 구성 관리자 별칭이어야 합니다. Address 키워드가 Server 키워드를 재정의합니다. 다음 중 하나를 지정하여 로컬 서버에서 기본 인스턴스에 연결할 수 있습니다.
SQL Server의 명명된 인스턴스를 지정하려면 \InstanceName을 추가합니다. 서버를 지정하지 않으면 로컬 컴퓨터의 기본 인스턴스에 연결합니다. IP 주소를 지정하는 경우 SQL Server 구성 관리자에서 TCP/IP 또는 명명된 파이프 프로토콜이 설정되어 있는지 확인합니다. Server 키워드에 대한 전체 구문은 다음과 같습니다. Server=[protocol:]Server[,port] protocol은 tcp(TCP/IP), lpc(shared memory) 또는 np(named pipes)일 수 있습니다. 프로토콜에 대한 자세한 내용은 네트워크 프로토콜 선택을 참조하십시오. 다음 예제는 명명된 파이프를 지정하는 방법입니다.
이 줄은 명명된 파이프 프로토콜, 로컬 시스템의 명명된 파이프(\\.\pipe), SQL Server 인스턴스 이름(MSSQL$MYINST01) 및 명명된 파이프의 기본 이름(sql/query)을 지정합니다. protocol 또는 Network 키워드가 지정되지 않은 경우 SQL Server Native Client는 SQL Server 구성 관리자에 지정된 프로토콜 순서를 사용합니다. port는 지정한 서버에서 연결할 포트입니다. 기본적으로 SQL Server는 포트 1433을 사용합니다. SQL Server Native Client를 사용할 때 ODBC 연결 문자열의 Server에 전달된 값의 시작 부분에 있는 공백은 무시됩니다. |
ServerSPN |
서버의 SPN입니다. 기본값은 빈 문자열입니다. 빈 문자열을 지정하면 SQL Server Native Client는 드라이버가 생성한 기본 SPN을 사용합니다. |
StatsLog_On |
"yes"인 경우 SQL Server Native Client ODBC 성능 데이터 캡처를 사용합니다. "no"인 경우 연결에서 SQL Server Native Client ODBC 드라이버 성능 데이터를 사용할 수 없습니다. |
StatsLogFile |
SQL Server Native Client ODBC 드라이버 성능 통계를 기록하는 데 사용되는 파일의 전체 경로와 파일 이름입니다. |
Trusted_Connection |
"yes"인 경우 SQL Server Native Client ODBC 드라이버가 Windows 인증 모드를 사용하여 로그인의 유효성을 검사하도록 지시합니다. 그렇지 않으면 SQL Server Native Client ODBC 드라이버가 SQL Server 사용자 이름과 암호를 사용하여 로그인 유효성을 검사하도록 지시하므로 UID 및 PWD 키워드를 지정해야 합니다. |
TrustServerCertificate |
Encrypt에서 사용할 경우 자체 서명된 서버 인증서를 통한 암호화를 사용합니다. |
UID |
유효한 SQL Server 로그인 계정입니다. Windows 인증을 사용할 경우 UID를 지정할 필요가 없습니다. |
UseProcForPrepare |
이 키워드는 더 이상 사용되지 않으며 SQL Server Native Client ODBC 드라이버는 이 설정을 무시합니다. |
WSID |
워크스테이션 ID로, 일반적으로 응용 프로그램이 있는 컴퓨터의 네트워크 이름입니다(옵션). 지정된 경우 이 값은 master.dbo.sysprocesses 열 hostname에 저장되며 sp_who 및 HOST_NAME 함수에서 반환됩니다. |
[!참고]
국가별 변환 설정이 통화, 숫자, 날짜 및 시간 데이터 형식에 적용됩니다. 변환 설정은 통화, 숫자, 날짜 또는 시간 값을 문자열로 변환한 경우에만 볼 수 있고 출력 변환에 적용할 수 있습니다.
SQL Server Native Client ODBC 드라이버는 현재 사용자의 로캘 레지스트리 설정을 사용합니다. 응용 프로그램에서 연결 이후에 SetThreadLocale을 호출하는 등의 방식으로 이를 설정하는 경우 드라이버는 현재 스레드의 로캘을 인식하지 못합니다.
데이터 원본의 국가별 동작을 변경하면 응용 프로그램에서 오류가 발생할 수 있습니다. 날짜 문자열을 구문 분석하며 날짜 문자열이 ODBC에 정의된 대로 표시될 것으로 예상하는 응용 프로그램에서 이 값을 변경하면 부정적인 영향을 줄 수 있습니다.
ADO(ActiveX Data Objects) 연결 문자열 키워드
ADO 응용 프로그램에서는 ADODBConnection 개체의 ConnectionString 속성을 설정하거나 ADODBConnection 개체의 Open 메서드에 대한 매개 변수로 연결 문자열을 제공합니다.
ADO 응용 프로그램에서는 OLE DB IDBInitialize::Initialize 메서드에 사용되는 키워드도 사용할 수 있지만 이러한 키워드는 기본값이 없는 속성에만 사용할 수 있습니다. 응용 프로그램이 초기화 문자열에 ADO 키워드와 IDBInitialize::Initialize 키워드를 모두 사용하는 경우에는 ADO 키워드 설정이 사용됩니다. 응용 프로그램에서 ADO 연결 문자열 키워드만 사용하는 것이 좋습니다.
ADO에서 사용하는 연결 문자열의 구문은 다음과 같습니다.
connection-string ::= empty-string[;] | attribute[;] | attribute; connection-string
empty-string ::=
attribute ::= attribute-keyword=["]attribute-value["]
attribute-value ::= character-string
attribute-keyword ::= identifier
특성 값을 큰따옴표로 묶을 수도 있으며, 그렇게 하는 것이 좋습니다. 그러면 값에 영숫자가 아닌 문자가 있을 경우 발생할 수 있는 문제를 막을 수 있습니다. 특성 값에는 큰따옴표가 있으면 안 됩니다.
다음 표에서는 ADO 연결 문자열에서 사용할 수 있는 키워드에 대해 설명합니다.
키워드 |
초기화 속성 |
설명 |
---|---|---|
Application Name |
SSPROP_INIT_APPNAME |
응용 프로그램을 식별하는 문자열입니다. |
Auto Translate |
SSPROP_INIT_AUTOTRANSLATE |
"AutoTranslate"에 대한 동의어입니다. |
AutoTranslate |
SSPROP_INIT_AUTOTRANSLATE |
OEM/ANSI 문자 변환을 구성합니다. 인식되는 값은 "true"와 "false"입니다. |
Connect Timeout |
DBPROP_INIT_TIMEOUT |
데이터 원본 초기화가 완료될 때까지 기다릴 시간(초)입니다. |
Current Language |
SSPROPT_INIT_CURRENTLANGUAGE |
SQL Server 언어 이름입니다. |
Data Source |
DBPROP_INIT_DATASOURCE |
조직의 SQL Server 인스턴스 이름입니다. 지정하지 않으면 로컬 컴퓨터의 기본 인스턴스에 연결합니다. 유효한 주소 구문에 대한 자세한 내용은 이 항목에 있는 Server ODBC 키워드에 대한 설명을 참조하십시오. |
DataTypeCompatibility |
SSPROP_INIT_DATATYPECOMPATIBILITY |
사용할 데이터 형식 처리 모드를 지정합니다. 인식되는 값은 "0"(공급자 데이터 형식) 및 "80"(SQL Server 2000 데이터 형식)입니다. |
Failover Partner |
SSPROP_INIT_FAILOVERPARTNER |
데이터베이스 미러링에 사용되는 장애 조치(Failover) 서버의 이름입니다. |
Failover Partner SPN |
SSPROP_INIT_FAILOVERPARTNERSPN |
장애 조치(Failover) 파트너의 SPN입니다. 기본값은 빈 문자열입니다. 빈 문자열을 지정하면 SQL Server Native Client는 공급자가 생성한 기본 SPN을 사용합니다. |
Initial Catalog |
DBPROP_INIT_CATALOG |
데이터베이스 이름입니다. |
Initial File Name |
SSPROP_INIT_FILENAME |
연결할 수 있는 데이터베이스의 전체 경로 이름을 포함한 주 파일의 이름입니다. AttachDBFileName을 사용하려면 공급자 문자열 DATABASE 키워드에도 데이터베이스 이름을 지정해야 합니다. 데이터베이스가 이전에 연결된 경우 SQL Server에서는 이 데이터베이스를 다시 연결하지 않으며 연결된 데이터베이스를 연결 기본값으로 사용합니다. |
Integrated Security |
DBPROP_AUTH_INTEGRATED |
Windows 인증을 위해 "SSPI" 값을 적용합니다. |
MARS Connection |
SSPROP_INIT_MARSCONNECTION |
서버가 SQL Server 2005 이상 버전인 경우 연결에서 MARS(Multiple Active Result Sets)를 설정하거나 해제합니다. 인식되는 값은 "true"와 "false"입니다. 기본값은 "false"입니다. |
Network Address |
SSPROP_INIT_NETWORKADDRESS |
조직의 SQL Server 인스턴스 네트워크 주소입니다. 유효한 주소 구문에 대한 자세한 내용은 이 항목에 있는 Address ODBC 키워드에 대한 설명을 참조하십시오. |
Network Library |
SSPROP_INIT_NETWORKLIBRARY |
조직의 SQL Server 인스턴스에 연결하는 데 사용하는 네트워크 라이브러리입니다. |
Packet Size |
SSPROP_INIT_PACKETSIZE |
네트워크 패킷 크기입니다. 기본값은 0이며 이는 서버가 sp_configure 'network packet size' 설정을 기반으로 패킷 크기를 구성함을 의미합니다. |
Password |
DBPROP_AUTH_PASSWORD |
SQL Server 로그인 암호입니다. |
Persist Security Info |
DBPROP_AUTH_PERSIST_SENSITIVE_AUTHINFO |
문자열 "true" 및 "false"를 값으로 받습니다. "false"인 경우 중요한 인증 정보를 데이터 원본 개체에 유지할 수 없습니다. |
Provider |
|
SQL Server Native Client의 경우 "SQLNCLI10"이어야 합니다. |
Server SPN |
SSPROP_INIT_SERVERSPN |
서버의 SPN입니다. 기본값은 빈 문자열입니다. 빈 문자열을 지정하면 SQL Server Native Client는 공급자가 생성한 기본 SPN을 사용합니다. |
Trust Server Certificate |
SSPROP_INIT_TRUST_SERVER_CERTIFICATE |
문자열 "true" 및 "false"를 값으로 받습니다. 기본값은 "false"이며 서버 인증서의 유효성을 검사하는 것을 의미합니다. |
Use Encryption for Data |
SSPROP_INIT_ENCRYPT |
데이터를 네트워크를 통해 보내기 전에 암호화해야 하는지 여부를 지정합니다. 가능한 값은 "true" 및 "false"입니다. 기본값은 "false"입니다. |
User ID |
DBPROP_AUTH_USERID |
SQL Server 로그인 이름입니다. |
Workstation ID |
SSPROP_INIT_WSID |
워크스테이션 식별자입니다. |
참고 연결 문자열에서 "이전 암호" 속성은 공급자 문자열 속성을 통해 사용할 수 없는 현재(만료된) 암호인 SSPROP_AUTH_OLD_PASSWORD를 설정합니다.