JDBC-드라이버 유형
JDBC 드라이버 란?
JDBC 드라이버는 데이터베이스 서버와 상호 작용하기 위해 JDBC API에 정의 된 인터페이스를 구현합니다.
예를 들어 JDBC 드라이버를 사용하면 데이터베이스 연결을 열고 SQL 또는 데이터베이스 명령을 보낸 다음 Java로 결과를 수신하여 데이터베이스 연결과 상호 작용할 수 있습니다.
JDK와 함께 제공 되는 Java.sql 패키지에는 동작이 정의 된 다양한 클래스가 포함되어 있으며 실제 구현은 타사 드라이버에서 수행됩니다. 타사 공급 업체 는 데이터베이스 드라이버에서 java.sql.Driver 인터페이스를 구현합니다 .
JDBC 드라이버 유형
JDBC 드라이버 구현은 Java가 작동하는 다양한 운영 체제 및 하드웨어 플랫폼으로 인해 다양합니다. Sun은 구현 유형을 아래에 설명 된 유형 1, 2, 3 및 4의 네 가지 범주로 나눴습니다.
유형 1 : JDBC-ODBC 브리지 드라이버
유형 1 드라이버에서 JDBC 브릿지는 각 클라이언트 시스템에 설치된 ODBC 드라이버에 액세스하는 데 사용됩니다. ODBC를 사용하려면 대상 데이터베이스를 나타내는 DSN (데이터 원본 이름)을 시스템에 구성해야합니다.
Java가 처음 나왔을 때 대부분의 데이터베이스가 ODBC 액세스 만 지원하기 때문에 유용한 드라이버 였지만 현재이 유형의 드라이버는 실험용으로 만 권장되거나 다른 대안이없는 경우에만 권장됩니다.
JDK 1.2와 함께 제공되는 JDBC-ODBC 브리지는 이러한 종류의 드라이버에 대한 좋은 예입니다.
유형 2 : JDBC-Native API
유형 2 드라이버에서 JDBC API 호출은 데이터베이스에 고유 한 기본 C / C ++ API 호출로 변환됩니다. 이러한 드라이버는 일반적으로 데이터베이스 공급 업체에서 제공하며 JDBC-ODBC 브리지와 동일한 방식으로 사용됩니다. 공급 업체별 드라이버는 각 클라이언트 컴퓨터에 설치해야합니다.
데이터베이스를 변경하면 기본 API를 변경해야합니다. 기본 API는 데이터베이스에 고유하고 현재 거의 사용되지 않습니다.하지만 ODBC의 오버 헤드를 제거하기 때문에 Type 2 드라이버를 사용하면 속도가 약간 증가 할 수 있습니다.
OCI (Oracle Call Interface) 드라이버는 유형 2 드라이버의 예입니다.
유형 3 : JDBC-Net 순수 Java
유형 3 드라이버에서는 3 계층 접근 방식을 사용하여 데이터베이스에 액세스합니다. JDBC 클라이언트는 표준 네트워크 소켓을 사용하여 미들웨어 애플리케이션 서버와 통신합니다. 그런 다음 소켓 정보는 미들웨어 애플리케이션 서버에 의해 DBMS에 필요한 호출 형식으로 변환되어 데이터베이스 서버로 전달됩니다.
이러한 종류의 드라이버는 클라이언트에 코드를 설치할 필요가없고 단일 드라이버가 실제로 여러 데이터베이스에 대한 액세스를 제공 할 수 있기 때문에 매우 유연합니다.
응용 프로그램 서버를 JDBC "프록시"로 생각할 수 있습니다. 즉, 클라이언트 응용 프로그램을 호출합니다. 따라서이 드라이버 유형을 효과적으로 사용하려면 응용 프로그램 서버의 구성에 대한 지식이 필요합니다.
애플리케이션 서버는 유형 1, 2 또는 4 드라이버를 사용하여 데이터베이스와 통신 할 수 있으며 뉘앙스를 이해하면 도움이 될 것입니다.
유형 4 : 100 % 순수 자바
Type 4 드라이버에서 순수한 Java 기반 드라이버는 소켓 연결을 통해 공급 업체의 데이터베이스와 직접 통신합니다. 이것은 데이터베이스에 사용할 수있는 최고 성능의 드라이버이며 일반적으로 공급 업체 자체에서 제공합니다.
이러한 종류의 드라이버는 매우 유연하므로 클라이언트 나 서버에 특별한 소프트웨어를 설치할 필요가 없습니다. 또한 이러한 드라이버는 동적으로 다운로드 할 수 있습니다.
MySQL의 Connector / J 드라이버는 Type 4 드라이버입니다. 네트워크 프로토콜의 독점적 특성으로 인해 데이터베이스 공급 업체는 일반적으로 유형 4 드라이버를 제공합니다.
어떤 드라이버를 사용해야합니까?
Oracle, Sybase 또는 IBM과 같은 한 가지 유형의 데이터베이스에 액세스하는 경우 선호하는 드라이버 유형은 4입니다.
Java 애플리케이션이 동시에 여러 유형의 데이터베이스에 액세스하는 경우 유형 3이 선호되는 드라이버입니다.
유형 2 드라이버는 데이터베이스에 아직 유형 3 또는 유형 4 드라이버를 사용할 수없는 상황에서 유용합니다.
유형 1 드라이버는 배포 수준 드라이버로 간주되지 않으며 일반적으로 개발 및 테스트 목적으로 만 사용됩니다.