mybatis-plus id主鍵生成的坑
簡要說明
由于mybatis-plus會自動插入一個id到實體對象, 不管你封裝與否, 所以有時候?qū)е乱恍┮馔獾那闆r發(fā)生
默認是生成一個長數(shù)字字符串(編碼不同可能結(jié)尾帶有字母)
錯誤
ested exception is org.apache.ibatis.reflection.ReflectionException: Could not set property 'id' of 'class com.xxx' with value '1110423703487479810' Cause: java.lang.IllegalArgumentException: java.lang.ClassCastException@14041406
大致就是由于自動生成了一個id1110423703487479810, 但是無法放入到integer中
解決方案一
1. 修改id字段類型
將id字段類型改為long, 這樣就能保證有足夠位數(shù)放入生成的id
2. 調(diào)整數(shù)據(jù)庫id字段類型
將數(shù)據(jù)庫的id字段的長度(改為20位)
解決方案二
如果想要使用id自增的, 就需要把mybatis-plus這個id生成的功能給關(guān)掉
添加注解
在id字段上加上如下注解即可
@TableId(value = "id",type = IdType.AUTO)
其他type類型介紹
- AUTO : AUTO(0, “數(shù)據(jù)庫ID自增”),
- INPUT : INPUT(1, “用戶輸入ID”),
- ID_WORKER : ID_WORKER(2, “全局唯一ID”),
- UUID : UUID(3, “全局唯一ID”),
- NONE : NONE(4, “該類型為未設(shè)置主鍵類型”),
- ID_WORKER_STR : ID_WORKER_STR(5, “字符串全局唯一ID”);
到此這篇關(guān)于mybatis-plus id主鍵生成的坑的文章就介紹到這了,更多相關(guān)mybatis-plus id主鍵生成內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java之實現(xiàn)十進制與十六進制轉(zhuǎn)換案例講解
這篇文章主要介紹了Java之實現(xiàn)十進制與十六進制轉(zhuǎn)換案例講解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-08-08
MyBatis學習教程(三)-MyBatis配置優(yōu)化
這篇文章主要介紹了MyBatis學習教程(三)-MyBatis配置優(yōu)化的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-05-05
springboot themaleaf 第一次進頁面不加載css的問題
這篇文章主要介紹了springboot themaleaf 第一次進頁面不加載css的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10
Spring之借助Redis設(shè)計一個簡單訪問計數(shù)器的示例
本篇文章主要介紹了Spring之借助Redis設(shè)計一個簡單訪問計數(shù)器的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-06-06

