Mybatis-plus全局id生成策略詳解
Mybatis-plus全局id生成策略
在配置文件中加入以下代碼後就不需要在實體類種的id上添加
@TableId(value = “id”, type = IdType.AUTO)
mybatis-plus: global-config: db-config: id-type: auto #設置主鍵自動生成策略(全局id生成策略)
Mybatis-plus6種主鍵生成策略小結
/** * 數據庫ID自增,數據庫需要支持主鍵自增(如MySQL),並設置主鍵自增 */ AUTO(0), /** * 該類型為未設置主鍵類型,默認使用雪花算法生成(snowflake) */ NONE(1), /** * 用戶輸入ID,數據類型和數據庫保持一致就行 * <p>該類型可以通過自己註冊自動填充插件進行填充</p> */ INPUT(2), /* 以下3種類型、隻有當插入對象ID 為空,才自動填充。 */ /** * 全局唯一ID (idWorker),數值類型 數據庫中也必須是數值類型 否則會報錯 * mp自帶策略,生成19位值,數字類型使用這種策略 比如long */ ID_WORKER(3), /** * 全局唯一ID (UUID,不含中劃線) * 每次生成隨即唯一的值 * 缺點:排序不方便 */ UUID(4), /** * 字符串全局唯一ID (idWorker 的字符串表示),數據庫也要保證一樣字符類型 * mp自帶策略,生成19位值 字符串類型使用這種策略 */ ID_WORKER_STR(5);
直接在實體類的主鍵字段加註解配置使用哪一種策略
舉例:
@TableId(type = IdType.ID_WORKER_STR) private String id;
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。
推薦閱讀:
- Mybatis Plus使用@TableId之坑及解決
- MybatisPlus中的insert操作詳解
- Mybatis-Plus自動生成的數據庫id過長的解決
- mybatis-plus 如何使用雪花算法ID生成策略
- mybatis-plus添加數據時id自增問題及解決