初學MyBatis(踩坑)Error querying database. Cause: java.sql.SQLException: java.lang.ClassCastException: java.math.BigInteger cannot be cast to java.lang.Long


最近在學習Mybatis,代碼全部根據教程寫好了,一運行結果報了一個錯誤,主要錯誤內容:

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?我跑去檢查實體類和數據庫,類型全部一一對應

User.class和數據庫對照表

斷點調試跑底層去,發現是連接數據庫出現了錯誤,然后我又跑去檢查mybatis配置文件,沒問題...

MyBatis配置文件

終於在百度快搜爛了的情況下發現了一個帖子(maven依賴版本不對應)傳送門

原帖

我的mysql-connector-java版本為5.1.23,而我本地mysql版本8.0+,mybatis版本3.5,我把mysql-connector-java版本對應本地mysql之后就好了....

錯誤版本

把依賴版本對應本地mysql版本

對應mysql版本

他來啦他來啦!!

查詢結果

(不知道mybatis版本需不需要對應,你們試試再來告訴我^.^)
歡迎來訪我的個人博客


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM