ODBC: ODBC 커서 라이브러리
이 항목에서는 ODBC 커서 라이브러리에 대해 설명하고 이 라이브러리를 사용하는 방법을 설명합니다. 자세한 내용은 다음을 참조하세요.
ODBC 커서 라이브러리는 ODBC 드라이버 관리자와 드라이버 사이에 있는 DLL(동적 연결 라이브러리)입니다. ODBC 용어에서 드라이버는 레코드 집합의 위치를 추적하기 위해 커서를 유지 관리합니다. 커서는 이미 스크롤한 레코드 집합의 위치(현재 레코드)를 표시합니다.
커서 라이브러리 및 수준 1 ODBC 드라이버
ODBC 커서 라이브러리는 수준 1 드라이버에 다음과 같은 새로운 기능을 제공합니다.
앞으로 및 뒤로 스크롤합니다. 수준 2 드라이버는 이미 스크롤할 수 있으므로 커서 라이브러리가 필요하지 않습니다.
스냅샷 지원. 커서 라이브러리는 스냅샷의 레코드를 포함하는 버퍼를 관리합니다. 이 버퍼는 프로그램의 삭제 및 레코드 편집을 반영하지만 다른 사용자의 추가, 삭제 또는 편집은 반영하지 않습니다. 따라서 스냅샷은 커서 라이브러리의 버퍼만큼만 최신입니다. 또한 버퍼는 호출
Requery
할 때까지 사용자 고유의 추가 사항을 반영하지 않습니다. 다이너셋은 커서 라이브러리를 사용하지 않습니다.
커서 라이브러리는 드라이버에서 일반적으로 지원되지 않는 경우에도 스냅샷(정적 커서)을 제공합니다. 드라이버가 이미 정적 커서를 지원하는 경우 스냅샷 지원을 받기 위해 커서 라이브러리를 로드할 필요가 없습니다. 커서 라이브러리를 사용하는 경우 스냅샷 및 전달 전용 레코드 집합만 사용할 수 있습니다. 드라이버가 다이너셋(KEYSET_DRIVEN 커서)을 지원하고 사용하려는 경우 커서 라이브러리를 사용하면 안 됩니다. 스냅샷과 다이내셋을 모두 사용하려면 드라이버가 둘 다 지원하지 않는 한 두 개의 서로 다른 CDatabase
개체(두 개의 서로 다른 연결)를 기반으로 해야 합니다.
배치된 업데이트 및 타임스탬프 열
참고 항목
이 항목에 설명된 대로 MFC ODBC 클래스를 통해 또는 MFC DAO(Data Access Object) 클래스를 통해 ODBC 데이터 원본에 액세스할 수 있습니다.
참고 항목
사용 가능한 경우 MFC에서 사용하는 ODBC 드라이버가 지원하는 SQLSetPos
경우 이 항목은 적용되지 않습니다.
대부분의 수준 1 드라이버는 위치 업데이트를 지원하지 않습니다. 이러한 드라이버는 커서 라이브러리를 사용하여 이와 관련하여 수준 2 드라이버의 기능을 에뮬레이트합니다. 커서 라이브러리는 흔들리지 않는 필드에서 검색된 업데이트를 수행하여 위치가 지정된 업데이트 지원을 에뮬레이트합니다.
경우에 따라 레코드 집합에 타임스탬프 열이 이러한 교환되지 않는 필드 중 하나로 포함될 수 있습니다. 타임스탬프 열이 포함된 테이블과 함께 MFC 레코드 집합을 사용하는 경우 두 가지 문제가 발생합니다.
첫 번째 문제는 타임스탬프 열이 있는 테이블에서 업데이트 가능한 스냅샷과 관련이 있습니다. 스냅샷이 바인딩된 테이블에 타임스탬프 열이 포함된 경우 호출한 Update
후 호출 Requery
Edit
해야 합니다. 그렇지 않은 경우 동일한 레코드를 다시 편집하지 못할 수 있습니다. 호출 Edit
한 다음 Update
레코드가 데이터 원본에 기록되고 타임스탬프 열이 업데이트됩니다. 호출 Requery
하지 않으면 스냅샷의 레코드에 대한 타임스탬프 값이 더 이상 데이터 원본의 해당 타임스탬프와 일치하지 않습니다. 레코드를 다시 업데이트하려고 하면 데이터 원본이 불일치로 인해 업데이트를 허용하지 않을 수 있습니다.
두 번째 문제는 테이블 간에 시간 및 날짜 정보를 전송하기 위해 함수와 함께 RFX_Date
사용할 때 클래스 CTime의 제한 사항과 관련이 있습니다. 개체를 처리하면 CTime
데이터 전송 중에 중간 처리의 형태로 약간의 오버헤드가 발생합니다. 일부 애플리케이션에서는 개체의 CTime
날짜 범위가 너무 제한될 수도 있습니다. 함수의 RFX_Date
새 버전은 개체 대신 ODBC TIMESTAMP_STRUCT 매개 변수를 CTime
사용합니다. 자세한 내용은 RFX_Date
MFC 참조의 매크로 및 전역 을 참조하세요.
커서 라이브러리 사용
CDatabase::OpenEx 또는 CDatabase::Open을 호출하여 데이터 원본에 연결할 때 데이터 원본에 커서 라이브러리를 사용할지 여부를 지정할 수 있습니다. 해당 데이터 원본에서 스냅샷을 만드는 경우 매개 변수의 옵션을 지정 CDatabase::useCursorLib
하거나 bUseCursorLib 매개 변수에 대해 TRUE를 Open
지정합니다(기본값은 TRUE).dwOptions
OpenEx
ODBC 드라이버가 다이너셋을 지원하고 데이터 원본에서 다이너셋을 열려면 커서 라이브러리를 사용하지 마세요(다이너셋에 필요한 일부 드라이버 기능을 마스킹). 이 경우 bUseCursorLib 매개 변수Open
에 OpenEx
대해 FALSE를 지정 CDatabase::useCursorLib
하거나 지정하지 마세요.