学习数据库连接池遇到的Bug总结

DBCP出现的Bug

今天跟着一本书在自学DBCP数据源的时候,刚开始采用通过BasicDataSource类直接创建数据源对象的方法,本来以为会很成功的一遍通过,毕竟也是跟着书上说的该导jar包导jar包(commons-dbcp.jar和commons-pool.jar以及mysql-connector-java-5.0.8-bin.jar),该导类导类,然现实很残忍,第一次就报出来了Bug,Bug 的内容如下:

java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory


不管怎么检查都发现自己写的代码没有问题,最后,百度了后才知道,原来是在使用dbcp的时候,还需要用commons-logging-1.2.jar这个jar包,然后在导入这个jar包后,成功运行,其运行结果如下:

当然,这些jar包都是可以从下载jar包的地址:http://commons.apache.org/proper/进行下载的,其下载的界面如下:

C3P0

采用C3P0数据源的时候,也是需要导入c3p0-0.9.5.2.jar(这是自己从网上下载的jar包),但是由于自己没有注意到,书上是导入的c3p0-0.9.1.2.jar,然后本来自己以为是没有事的,但是却出现了如下的Bug:

java.lang.NoClassDefFoundError: com/mchange/v2/ser/Indirector

其截图如下:

经过反复检查代码,也没有出错,于是,再次选择常人的办法,访问了度娘,原来出现这种bug并非意外,而是:
在c3p0-0.9.1.2.jar jar包之前,还是一个jar包就可以解决一切事情,但是从该版本之后,当再次用c3p0的时候,需要与mchange-commons-java-0.2.12.jar进行配合使用,不然就会报该Bug
当再一次把这个jar包给导进去的时候,bug便成功解决了,运行成功的截图如下:

总结

虽然现在用的数据库连接池以及DBUtil等工具越来越少,但是在我们学习SSM框架的时候,想要了解其底层代码,肯定是对其了解的越多越好,然,其代码并不多,程序也不复杂,但是在进行自己学习的时候一定要注意jar包的导入和版本,稍有不慎,看见Bug很难受的哟

附C3P0的完整jar包

链接:https://pan.baidu.com/s/1CLdxAW9CMdg9toHsLAy07w
提取码:s6by

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值