查看db2jcc.jar的版本信息

一般安装了db2之后可以在此目录找到jdbc驱动:

/home/db2inst1/sqllib/java/

查看jdbc驱动程序db2jcc.jar的版本命令如下:

java -cp ./db2jcc.jar com.ibm.db2.jcc.DB2Jcc -version
java -cp ./db2jcc4.jar com.ibm.db2.jcc.DB2Jcc -version

依照 JDBC 规范,有四种类型的 JDBC 驱动程序体系结构:

Type 1:这类驱动程序将 JDBC API 作为到另一个数据访问 API 的映射来实现,如开放式数据库连通性(Open Database Connectivity,ODBC)。这类驱动程序通常依赖本机库,这限制了其可移植性。JDBC-ODBC 桥驱动程序就是 Type 1 驱动程序的最常见的例子。
Type 2:这类驱动程序部分用 JAVA 编程语言编写,部分用本机代码编写。这些驱动程序使用特定于所连接数据源的本机客户端库。同样,由于使用本机代码,所以其可移植性受到限制。
Type 3:这类驱动程序使用纯 JAVA 客户机,并使用独立于数据库的协议与中间件服务器通信,然后中间件服务器将客户机请求传给数据源。
Type 4:这类驱动程序是纯 JAVA,实现针对特定数据源的网络协议。客户机直接连接至数据源。
对于DB2 UDB V7.2来说,它不支持 Type 1 和 Type 4 的驱动程序,但是提供了分别支持 Type 2 和 Type 3 的驱动程序。

示例如下:

两种驱动程序均随产品安装由 db2java.zip 提供。

COM.ibm.db2.jdbc.app.DB2Driver
这是一种 Type 2 的 JDBC 驱动程序,它通过 DB2 本地客户机库的帮助建立和 DB2本地数据库或是远程数据库的连接(事先将远程数据库编目到本地)。因此,我们必须在应用系统所在的机器上同时部署 DB2 本地客户机库,这也许是它最大的一个不足之处。

使用格式如下:

Driver Name:COM.ibm.db2.jdbc.app.DB2Driver

URL Pattern:jdbc:db2:databasename

databasename: 需要访问的数据库名

COM.ibm.db2.jdbc.net.DB2Driver
这是一种 Type 3 的 JDBC 驱动程序,它通过与一台已经部署了 DB2 本地客户机库的机器通信来建立和 DB2 远程数据库的连接。

使用格式如下:

Driver Name:COM.ibm.db2.jdbc.net.DB2Driver

URL Pattern:jdbc:db2:ServerIP:databasename

ServerIP: 需要访问的数据库所在机器IP地址

databasename: 需要访问的数据库名

(目标DB2系统侦听该服务于默认端口6789,否则还需要在 URL Pattern 中指定目标端口号)

对于 DB2 UDB V8.1 来说,它仍然不支持 Type 1 的驱动程序。同时,它在 DB2 UDB V8.1的基础上,新增加了对 Type 4 驱动程序的支持。

示例如下:

DB2 UDB V8.1 仍然支持上面所述 V7.2 支持的两种驱动程序,随产品安装由 db2java.zip 提供,但具体实现上和 DB2 UDB V7.2 产品发布的包有所不同,所以可能存在轻微兼容性问题。

除了 COM.ibm.db2.jdbc.app.DB2Driver 之外,DB2 UDB V8.1 还提供了另外一种 Type 2 的驱动程序,随产品安装由 db2jcc.jar 提供。其实现包名是 com.ibm.db2.jcc.DB2Driver,在DB2 UDB V8.1 最初的实现中,此驱动程序只用于使用 Type 4 驱动程序体系结构与 DB2 服务器进行直接的 JAVA 连接,这类驱动程序由于不需要另外部署 DB2 本地客户机库以及性能相对较好而收到开发人员的欢迎。自从 DB2 UDB V8.1.2(安装了 FixPack 2)之后,开发人员还可以在 Type 2 体系结构中使用该驱动程序,以提高本地应用程序的性能。

这里,两种驱动程序具有相同的实现类名称,有两种不同的方法可以区分 DB2 系统在内部最终会实例化哪个驱动程序:

使用不同的 URL Pattern 来区分两种不同的驱动程序
Type 2 Driver URL Pattern:jdbc:db2:databasename

这当中 databasename 是需要访问的数据库名

Type 4 Driver URL Pattern:jdbc:db2://ServerIP:50000/databasename

这当中 ServerIP 是需要访问的数据库所在机器IP地址,databasename 是需要访问的数据库名,DB2 服务器会在默认端口 50000 上进行侦听。

使用连接特性来区分数据库连接是否会使用 DB2 本地客户机库,或者是使用JAVA 直接连接。
DB2 UDB V8.1 新增加支持的这种 Type 4 驱动程序,常被称为“通用 JDBC 驱动程序”,是一种与驱动程序类型连通性或目标平台无关的抽象 JDBC 处理器,因此常用于进行分布式和本地 DB2 UDB 访问。因为“通用 JDBC 驱动程序”独立于任何特定 JDBC 驱动程序类型连通性或目标平台,所以它在一个 DB2 UDB 驱动程序实例中同时支持所有 JAVA 连通性(Type 4 驱动程序)和基于 JNI 的连通性(Type 2 驱动程序)。该驱动程序可以用于独立 JAVA 应用程序或多层应用程序,是开发人员一个不错的选择。

DB2对JDBC4的支持

JDBC 3.0支持SQL99的子集; JDBC 4.0支持SQL2003的子集。JDK 6 开始支持 JDBC 4.0。

安装完DB2 Server V9.5后 “SQLLIB\java”目录中db2jcc4.jar (for JDBC)和sqlj4.zip (for SQLJ)是用于支持JDBC 4的。

缺省CLASSPATH路径中用的是db2jcc.jar,而不是db2jcc4.jar。所以如果要用JDBC4需要设置CLASSPATH环境变量。

DB2 V9.5.0中虽然有db2jcc4.jar,但是DB2附带的JDK是v1.5,所以需要另外安装一个JDK v1.6。

DB2 V9.7中附带的JDK是v1.6,支持JDBC4.0

最 新的IBM Data Server Driver for JDBC and SQLJ (JCC Driver) V9.7 (internal version 3.57&4.7)中同时包含了db2jcc.jar/sqlj.zip和db2jcc4.jar/sqlj4.zip,同时支持JDBC3.0 和JDBC4.0。

在一般的应用中还需要license.jar的,以下为两者的区别。

db2jcc_license_cu.jar & db2jcc_license_cisuz.jar
The following table describes the license requirements for connecting to DB2 databases.
db2jcc_license_cu.jar Permits JDBC/SQLJ connectivity to all DB2 Universal Database for Linux?, UNIX?, and Windows? servers and Cloudscape?. This is the standard license provided with DB2 Universal Database for Linux, UNIX, and Windows. db2jcc_license_cu.jar is included with all of the editions of DB2 Universal Database for Linux, UNIX, and Windows.
db2jcc_license_cisuz.jar Permits JDBC/SQLJ connectivity to all DB2 servers, including: DB2 Universal Database for z/OS?; DB2 Universal Database for iSeries?; DB2 Universal Database for Linux, UNIX, and Windows; and Cloudscape. This license is provided to DB2 Connect? licensees only. db2jcc_license_cisuz.jar is included with all DB2 Connect editions.

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值