Mybatis Plus使用@TableId之坑及解決
Mybatis Plus使用@TableId之坑
1. TableId 可選類型
不添加註解時,默認使用ID_WORKER(3)
public enum IdType { /** * 數據庫ID自增 */ AUTO(0), /** * 該類型為未設置主鍵類型(將跟隨全局) */ NONE(1), /** * 用戶輸入ID * <p>該類型可以通過自己註冊自動填充插件進行填充</p> */ INPUT(2), /* 以下3種類型、隻有當插入對象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;
- 數據庫主鍵id,mysql必須設置自增主鍵,postgreSQL必須設置自增序列,才能夠使用此註解。
3. @TableId(value = “id”,type= IdType.ID_WORKER)
使用條件:
- id 類型必須是Long;
- 因為ID_WORKER 生成的snowflakeId 是19位的全局id。
Mybatis Plus TableId無效
初次使用mybatisplus,剛開始正常,後來發現插入時總是duplicate key,百事不得其解,後發現問題如下
@TableId(type = IdType.ID_WORKER) private Long id; # 正確 private long id; # 錯誤 private int id; # 錯誤
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。
記錄一次腦癱操作。。。。
推薦閱讀:
- Mybatis-plus全局id生成策略詳解
- MybatisPlus中的insert操作詳解
- Mybatis-Plus自動生成的數據庫id過長的解決
- mybatis-plus 如何使用雪花算法ID生成策略
- mybatis-plus添加數據時id自增問題及解決