关于项目中数据库驱动jar、JDK和连接池DBCP jar之间的版本匹配

本文讨论了项目中遇到的数据库连接池DBCP错误问题,指出DBCP的不同版本对应不同的JDBC规范,如DBCP 1.4支持JDK 1.6(JDBC 4),1.3支持JDK 1.4-1.5(JDBC 3)。同时,介绍了JDK对JDBC版本的支持情况,例如JDK 1.6支持JDBC4。对于Oracle 10g数据库,建议使用JDK 1.4或1.5及DBCP 1.4版本,以避免兼容性问题。若JDBC版本具备向下兼容性,不匹配可能导致局部代码冲突。
摘要由CSDN通过智能技术生成

       今天听同事说有一个web项目,在本地测试都是可以的,上线后试运行也可以,但是过几个小时就会出错连接池报错的问题。DBCP在项目中使用非常广泛。应该不太会是配置上出错。上apache官网上看了下,发现原来DBCP不同版本的jar包是支持不同版本的JDBC规范的。如下:

  • DBCP 1.4 compiles and runs under JDK 1.6 only (JDBC 4)
  • DBCP 1.3 compiles and runs under JDK 1.4-1.5 only (JDBC 3)

而JDK对JDBC版本支持的规范如下:

JDK 1.1 - JDBC 1. Note that with the 8.0 release JDBC 1 support has been removed, so look to update your JDK when you update your server.

JDK 1.2, 1.3 - JDBC 2.

JDK 1.3 + J2EE - JDBC 2 EE. This contains additional support for javax.sql classes.

JDK 1.4, 1.5 - JDBC 3. This contains support for SSL and javax.sql, but does not require J2EE as it has been added to the J2SE release.

JDK 1.6 - JDBC4. Support for JDBC4 methods is limited. The driver builds, but the majority of new methods are stubbed out.

 

而oracle提供的jar一般是10g是支持jdk1.4的,这从它的名字ojdbc14.jar上就能看出来。

 

那么这样一来,我们项目如果是oracle10g的数据库,那么JDK最好是使用1.4或1.5,DBCP则使用1.4版本,否则容易出现jar包兼容性问题。

(注:不知JDBC各个版本的规范是否具有向下兼容机制,如果是具备向下兼容,那么上述jar选择应该只是可能会造成一些局部代码冲突问题)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值