IBM公司的DB2数据库应用非常广泛,本文将为您介绍DB2数据库的驱动类型说明,对于特定的DB2版本的驱动有特定的驱动,也有通用的驱动。如果您对此方面感兴趣,不妨一看。
IBM公司的数据库产品线中不同版本所提供的相关数据访问API,其可以说是已经很多了,其中包括最早期的基于CLI的驱动,最近的纯Java的驱动,以及CLI和Java的组合。
对于特定的DB2版本的驱动有特定的驱动也有通用的驱动,这是很明显的.
一般说明
IBM公司的数据库产品线中不同版本提供的数据访问API可以说是很多了,其中包括早期的基于CLI的驱动,最近的纯Java的驱动,以及CLI和 Java的组合.对于特定的DB2版本的驱动有特定的驱动也有通用的驱动,这是很明显的.但是诸多版本的数据库系统和诸多版本的访问驱动,放在客户面前,它们之间的关系显得有些纷繁.
所以在使用IBM的数据库产品时,头脑中一定要注意版本对应和选择适当的通用驱动.还好,IBM已经开始走向统一了,也开始注意易用性了,这些努力从DB2 UDB V7就开始了.从那时开始,按照Java领域JDBC驱动的类型划分,IBM有了三类驱动了.
DB2的JDBC TYPE 2 驱动使 Java 应用程序通过JDBC调用DB2驱动类型.对 DB2 JDBC type 2 driver 的调用被转换成 Java 本地方法.Java 使用这种驱动程序的应用程序必须运行在一个 DB2 客户机上。
JDBC 请求通过这个客户机转到 DB2 服务器.在使用 DB2 JDBC 应用程序驱动程序访问 DB2 UDB for iSeries 数据源或者 DB2 for OS/390 或 z/OS 环境中的数据源之前,必须安装 DB2 Connect Version 8.DB2 JDBC type 2 driver 支持 JDBC 1.2 规范中描述的大部分 JDBC 和 SQLJ 函数,并且支持 JDBC 2.0 规范中描述的一些函数.
DB2的JDBC TYPE 3 驱动,也被称为applet 或net driver,它由一个JDBC 客户机和一个JDBC 服务器(该进程的名字是db2jd)组成.既可以在Applet中使用也可以在应用程序中使用.
DB2的JDBC TYPE 4 驱动被称为通用驱动,是纯Java实现的,该驱动也支持SQLJ.
目前IBM一直都没有提供 TYPE 1的JDBC驱动程序.
这些类型驱动程序所在的包是:db2驱动类型jcc.jar 和 sqlj.zip 文件,sqllibbindb2jcct2.dll(该文件是 TYPE2所必需的).
使用
在使用 JDBC 连接 DB2 UDB V7.2 和 DB2 UDB V8.1 时,如果碰到一些令人费解的问题,可以检查一下开发环境使用的JDK,在IBM提供的已知JDK中切换(目前有1.3和1.4版本),往往就能解决你的问题。
DB2 UDB V8.2个人版本中,下面的测试代码测试了三种连接方式,并给出了结果:
import java.sql.*; public class Employee { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub Employee ee = new Employee(); try { ee.testJcc(); 成功
ee.testNet(); 成功
ee.testApp(); 失败,原因是:类型2需要安装DB2驱动类型访问客户端,测试没有安装.如果要通过类型2访问远程数据库,可以把远程数据库编目到本地后即可.
} catch (Exception e) { e.printStackTrace(); } } /**