## c3p0运行时报了很多java.Long.NullPointerException
在最近学习c3p0的时候,自己利用链接池的便捷去做了一个单表curd的项目,但是在运行测试的时候,报了很多异常。
当看到空指针的时候我还以为我的方法return null了,所以打了断点去观察了一下。结果发现一直处于连接池去读取c3p0-cofig.xml文件的死循环中,于是我就开始了问老师+问度娘的漫长过程中,好在最后解决了,我总结了一下我问老师+问度娘的解决方法:
-
有可能是sql的相关服务没有开启
因为下面报了一句 java.lang.RuntimeException: java.sq1.SQLException:Connections could not be acquired from the underlying database!意思是:“无法从底层数据库获取连接!“
解决方法很简单:
选中此电脑然后右键找到管理点击,在里面找到服务和应用程序然后找到你用的数据库的相关服务关闭在重新打开就行了。
-
第二种方法是有可能你的DataSource读取了c3p0-cofig.xml,但是你的服务器没有给授权,这时候只需要连接你的数据库输入grant all privileges on . to ‘root’@’%’ identified by ‘root’ with grant option;
flush privileges;并且按两下回车就可以了。
-
第三种方法也是最扯淡的方法,那就是你的xml文件路径有问题,导致你的DataSource读取不到c3p0配置文件,这时候只需要把原来的删除了然后在拉到src下面就可以了,加入你原来的也在src下面,那你也同样在重新拉一次。