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

       今天听同事说有一个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选择应该只是可能会造成一些局部代码冲突问题)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值