c3p0报了很多空指针

## c3p0运行时报了很多java.Long.NullPointerException

在最近学习c3p0的时候,自己利用链接池的便捷去做了一个单表curd的项目,但是在运行测试的时候,报了很多异常。

在这里插入图片描述
当看到空指针的时候我还以为我的方法return null了,所以打了断点去观察了一下。结果发现一直处于连接池去读取c3p0-cofig.xml文件的死循环中,于是我就开始了问老师+问度娘的漫长过程中,好在最后解决了,我总结了一下我问老师+问度娘的解决方法:

  1. 有可能是sql的相关服务没有开启

    因为下面报了一句 java.lang.RuntimeException: java.sq1.SQLException:Connections could not be acquired from the underlying database!意思是:“无法从底层数据库获取连接!“

    解决方法很简单:
    选中此电脑然后右键找到管理点击,在里面找到服务和应用程序然后找到你用的数据库的相关服务关闭在重新打开就行了。
    在这里插入图片描述

  2. 第二种方法是有可能你的DataSource读取了c3p0-cofig.xml,但是你的服务器没有给授权,这时候只需要连接你的数据库输入grant all privileges on . to ‘root’@’%’ identified by ‘root’ with grant option;
    flush privileges;

    并且按两下回车就可以了。
    在这里插入图片描述

  3. 第三种方法也是最扯淡的方法,那就是你的xml文件路径有问题,导致你的DataSource读取不到c3p0配置文件,这时候只需要把原来的删除了然后在拉到src下面就可以了,加入你原来的也在src下面,那你也同样在重新拉一次。

在这里插入图片描述

总结:说实话看到这种异常还是蛮头疼的,毕竟不好找到问题的根源性,希望这篇文章对你有所帮助。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值