最近在学习Mybatis,代码所有根据教程写好了,一运行结果报了一个错误,主要错误内容:java
Caused by: org.apache.ibatis.exceptions.PersistenceException: ### Error querying database. Cause: java.sql.SQLException: java.lang.ClassCastException: java.math.BigInteger cannot be cast to java.lang.Long ### The error may exist in com/ctong/crm/dao/UserDao.xml ### The error may involve com.ctong.crm.dao.UserDao.login ### The error occurred while executing a query ### Cause: java.sql.SQLException: java.lang.ClassCastException: java.math.BigInteger cannot be cast to java.lang.Long at org.apache.ibatis.exceptions.ExceptionFactory.wrapException(ExceptionFactory.java:30) at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:149) at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:140) at org.apache.ibatis.session.defaults.DefaultSqlSession.selectOne(DefaultSqlSession.java:76) at org.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:87) at org.apache.ibatis.binding.MapperProxy$PlainMethodInvoker.invoke(MapperProxy.java:144) at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:85) at com.sun.proxy.$Proxy5.login(Unknown Source) at com.ctong.crm.service.impl.UserServiceImpl.login(UserServiceImpl.java:42) ... 31 more
说什么BigInteger没法转Long?我跑去检查实体类和数据库,类型所有一一对应mysql
断点调试跑底层去,发现是链接数据库出现了错误,而后我又跑去检查mybatis配置文件,没问题...sql
终于在百度快搜烂了的状况下发现了一个帖子(maven依赖版本不对应)传送门数据库
个人mysql-connector-java
版本为5.1.23,而我本地mysql版本8.0+,mybatis
版本3.5,我把mysql-connector-java
版本对应本地mysql以后就行了....apache
把依赖版本对应本地mysql版本session
他来啦他来啦!!mybatis
(不知道mybatis版本需不须要对应,大家试试再来告诉我^.^)
欢迎来访个人我的博客app