다음을 통해 공유


ODBC 3.x 애플리케이션 작성

ODBC 2.x 애플리케이션이 ODBC 3.x로 업그레이드되면 ODBC 2.x3.x 드라이버 모두에서 작동하도록 작성해야 합니다. 애플리케이션은 ODBC 3.x 기능을 최대한 활용하기 위해 조건부 코드를 통합해야 합니다.

SQL_ATTR_ODBC_VERSION 환경 특성은 SQL_OV_ODBC2 설정해야 합니다. 이렇게 하면 동작 변경 섹션에 설명된 변경 내용과 관련하여 드라이버가 ODBC 2.x 드라이버처럼 동작합니다.

애플리케이션이 새 기능 섹션에 설명된 기능을 사용하는 경우 조건부 코드를 사용하여 드라이버가 ODBC 3.x 또는 ODBC 2.x 드라이버인지 여부를 확인해야 합니다. 애플리케이션은 SQLGetDiagFieldSQLGetDiagRec를 사용하여 이러한 조건부 코드 조각에서 오류 처리를 수행하는 동안 ODBC 3.x SQLSTATE를 가져옵니다. 새 기능에 대한 다음 사항을 고려해야 합니다.

  • 행 집합 크기 동작의 변경으로 영향을 받는 애플리케이션은 배열 크기가 1보다 클 때 SQLFetch를 호출하지 않도록 주의해야 합니다. 이러한 애플리케이션은 ODBC 3.x 및 ODBC 2.x 드라이버에서 작동하는 공통 코드를 갖도록 SQLExtendedFetch 호출을 sqlSetStmtAttr 호출로 바꾸어 SQL_ATTR_ARRAY_STATUS_PTR 문 특성 및 SQLFetchScroll을 설정해야 합니다. SQL_ATTR_ROW_ARRAY_SIZE 있는 SQLSetStmtAttr은 ODBC 2.x 드라이버에 대한 SQL_ROWSET_SIZE 사용하여 SQLSetStmtAttr에 매핑되므로 애플리케이션은 다중 로 가져오기 작업에 대한 SQL_ATTR_ROW_ARRAY_SIZE 설정할 수 있습니다.

  • 업그레이드하는 대부분의 애플리케이션은 실제로 SQLSTATE 코드의 변경 내용에 영향을 받지 않습니다. 영향을 받는 애플리케이션의 경우 대부분의 경우 "SQLSTATE 매핑" 섹션의 오류 변환 테이블을 사용하여 기계 검색을 수행하고 대체하여 ODBC 3.x 오류 코드를 ODBC 2.x 코드로 변환할 수 있습니다. ODBC 3.x 드라이버 관리자는 ODBC 2.x SQLSTATE에서 ODBC 3.x SQLSTATE로 매핑을 수행하므로 이러한 애플리케이션 작성기는 ODBC 3.x SQLSTATE에 대한 검사 필요하고 조건부 코드에 ODBC 2.x SQLSTATE를 포함할 필요가 없습니다.

  • 애플리케이션이 날짜, 시간 및 타임스탬프 데이터 형식을 잘 사용하는 경우 애플리케이션은 자신을 ODBC 2.x 애플리케이션으로 선언하고 컨디셔닝 코드를 사용하는 대신 기존 코드를 사용할 수 있습니다.

업그레이드에는 다음 단계도 포함되어야 합니다.

  • 연결을 할당하기 전에 SQLSetEnvAttr를 호출하여 SQL_ATTR_ODBC_VERSION 환경 특성을 SQL_OV_ODBC2 설정합니다.

  • SQLAllocEnv, SQLAlloc커넥트 또는 SQLAllocStmt에 대한 모든 호출을 SQLAllocHandle대한 호출로 SQL_HANDLE_ENV, SQL_HANDLE_DBC 또는 SQL_HANDLE_STMT 적절한 HandleType 인수로 바꿉다.

  • SQLFreeEnv 또는 SQLFree커넥트에 대한 모든 호출을 SQLFreeHandle에 대한 호출로 SQL_HANDLE_DBC 또는 SQL_HANDLE_STMT 적절한 HandleType 인수로 바꿉다.

  • SQLSet커넥트Option대한 모든 호출을 SQLSet커넥트Attr에 대한 호출로 대체합니다. 값이 문자열인 특성을 설정하는 경우 StringLength 인수를 적절하게 설정합니다. 특성 인수를 SQL_XXXX SQL_ATTR_XXXX 변경합니다.

  • SQLGet커넥트Option대한 모든 호출을 SQLGet커넥트Attr대한 호출로 대체합니다. 문자열 또는 이진 특성을 가져오는 경우 BufferLength를 적절한 값으로 설정하고 StringLength 인수를 전달합니다. 특성 인수를 SQL_XXXX SQL_ATTR_XXXX 변경합니다.

  • SQLSetStmtOption대한 모든 호출을 SQLSetStmtAttr대한 호출로 대체합니다. 값이 문자열인 특성을 설정하는 경우 StringLength 인수를 적절하게 설정합니다. 특성 인수를 SQL_XXXX SQL_ATTR_XXXX 변경합니다.

  • SQLGetStmtOption대한 모든 호출을 SQLGetStmtAttr 호출로 대체합니다. 문자열 또는 이진 특성을 가져오는 경우 BufferLength를 적절한 값으로 설정하고 StringLength 인수를 전달합니다. 특성 인수를 SQL_XXXX SQL_ATTR_XXXX 변경합니다.

  • SQLTransact에 대한 모든 호출을 SQLEndTran에 대한 호출로 대체합니다. SQLTransact 호출에서 가장 올바른 핸들이 환경 핸들인 경우 적절한 Handle 인수를 사용하여 SQLEndTran 호출에서 SQL_HANDLE_ENV HandleType 인수를 사용해야 합니다. SQLTransact 호출에서 가장 올바른 핸들이 연결 핸들인 경우 적절한 Handle 인수를 사용하여 SQLEndTran 호출에서 SQL_HANDLE_DBC HandleType 인수를 사용해야 합니다.

  • SQLColAttributes에 대한 모든 호출을 SQLColAttribute 호출로 대체합니다. FieldIdentifier 인수가 SQL_COLUMN_PRECISION, SQL_COLUMN_SCALE 또는 SQL_COLUMN_LENGTH 경우 함수 이름 이외의 다른 항목은 변경하지 마세요. 그렇지 않은 경우 FieldIdentifier를 SQL_COLUMN_XXXX SQL_DESC_XXXX 변경합니다. FieldIdentifier가 SQL_DESC_CONCISE_TYPE 데이터 형식이 datetime 데이터 형식인 경우 해당 ODBC 3.x 데이터 형식으로 변경합니다.

  • 블록 커서, 스크롤 가능한 커서 또는 둘 다를 사용하는 경우 애플리케이션은 다음을 수행합니다.

    • SQLSetStmtAttr를 사용하여 행 집합 크기, 커서 형식 및 커서 동시성을 설정합니다.

    • SQLSetStmtAttr를 호출하여 상태 레코드 배열을 가리키도록 SQL_ATTR_ROW_STATUS_PTR 설정합니다.

    • SQLSetStmtAttr를 호출하여 SQLINTEGER를 가리키도록 SQL_ATTR_ROWS_FETCHED_PTR 설정합니다.

    • 필요한 바인딩을 수행하고 SQL 문을 실행합니다.

    • 루프에서 SQLFetchScroll을 호출하여 행을 가져오고 결과 집합에서 이동합니다.

    • 책갈피로 페치하려는 경우 애플리케이션은 SQLSetStmtAttr를 호출하여 SQL_ATTR_FETCH_BOOKMARK_PTR 가져오려는 행의 책갈피를 포함하는 변수로 설정하고 SQL_FETCH_BOOKMARK FetchOrientation 인수를 사용하여 SQLFetchScroll을 호출 합니다.

  • 매개 변수 배열을 사용하는 경우 애플리케이션은 다음을 수행합니다.

    • SQLSetStmtAttr을 호출하여 SQL_ATTR_PARAMSET_SIZE 특성을 매개 변수 배열의 크기로 설정합니다.

    • SQLSetStmtAttr를 호출하여 내부 UDWORD 변수를 가리키도록 SQL_ATTR_ROWS_PROCESSED_PTR 설정합니다.

    • 적절하게 준비, 바인딩 및 실행 작업을 수행합니다.

    • SQL_NEED_DATA 등의 이유로 실행이 중단되는 경우 SQL_ATTR_ROWS_PROCESSED_PTR 가리키는 위치를 검사하여 매개 변수의 "현재" 행을 찾을 수 있습니다.

이 섹션에서는 다음 항목을 다룹니다.