Mybatis?Plus使用@TableId之坑及解決
Mybatis Plus使用@TableId之坑
1. TableId 可選類型
不添加注解時,默認使用ID_WORKER(3)
public enum IdType { /** * 數(shù)據(jù)庫ID自增 */ AUTO(0), /** * 該類型為未設(shè)置主鍵類型(將跟隨全局) */ NONE(1), /** * 用戶輸入ID * <p>該類型可以通過自己注冊自動填充插件進行填充</p> */ INPUT(2), /* 以下3種類型、只有當(dāng)插入對象ID 為空,才自動填充。 */ /** * 全局唯一ID (idWorker) */ ID_WORKER(3), /** * 全局唯一ID (UUID) */ UUID(4), /** * 字符串全局唯一ID (idWorker 的字符串表示) */ ID_WORKER_STR(5); }
2. @TableId(value = “id”,type= IdType.AUTO)
使用條件:
- id 類型可以是Interger/Long;
- 數(shù)據(jù)庫主鍵id,mysql必須設(shè)置自增主鍵,postgreSQL必須設(shè)置自增序列,才能夠使用此注解。
3. @TableId(value = “id”,type= IdType.ID_WORKER)
使用條件:
- id 類型必須是Long;
- 因為ID_WORKER 生成的snowflakeId 是19位的全局id。
Mybatis Plus TableId無效
初次使用mybatisplus,剛開始正常,后來發(fā)現(xiàn)插入時總是duplicate key,百事不得其解,后發(fā)現(xiàn)問題如下
@TableId(type = IdType.ID_WORKER) private Long id; # 正確 private long id; # 錯誤 private int id; # 錯誤
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
記錄一次腦癱操作。。。。
相關(guān)文章
java讀取配置文件自定義字段(yml、properties)
本文主要介紹了java讀取配置文件自定義字段(yml、properties),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07詳解SpringMVC中的四種跳轉(zhuǎn)方式、視圖解析器問題
這篇文章主要介紹了SpringMVC的四種跳轉(zhuǎn)方式、視圖解析器,springmvc核心配置文件和視圖解析器的使用,添加視圖解析器,通過案例講解四種跳轉(zhuǎn)方式,需要的朋友可以參考下2022-10-10maven多moudle項目在idea里面顯示多個root問題及解決
這篇文章主要介紹了maven多moudle項目在idea里面顯示多個root問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05java之Timer和TimerTask簡單demo(分享)
下面小編就為大家?guī)硪黄猨ava之Timer和TimerTask簡單demo(分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-12-12java字符串轉(zhuǎn)數(shù)字及各種數(shù)字轉(zhuǎn)字符串的3種方法
這篇文章主要介紹了java字符串轉(zhuǎn)數(shù)字及各種數(shù)字轉(zhuǎn)字符串的3種方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-09-09Springboot基于assembly的服務(wù)化打包方案及spring boot部署方式
這篇文章主要介紹了Springboot基于assembly的服務(wù)化打包方案及springboot項目的幾種常見的部署方式,本文主要針對第二種部署方式提供一種更加友好的打包方案,需要的朋友可以參考下2017-12-12