MybatisPlus 主鍵策略之type=IdType.ASSIGN_ID等詳解
主鍵策略
我們可以通過@TableId注解的 類型屬性來設置主鍵id的增長策略,一共有幾個多個主鍵策略,可根據(jù)情況自由配置。
1,ASSIGN_ID(雪花算法)
如果不設置類型值,默認則使用IdType.ASSIGN_ID策略(自3.3.0起)。該策略會使用雪花算法自動生成主鍵ID,主鍵類型為長或字符串(分別對應的MySQL的表字段為BIGINT和VARCHAR)
提示:該策略使用接口IdentifierGenerator的方法nextId(以實現(xiàn)類為DefaultIdentifierGenerator雪花算法),下面是雪花算法介紹:
雪花算法(雪花)是微博開源的分布式ID生成算法其核心思想就是:使用一個64位的長型的數(shù)字作為全局唯一ID。在分布式系統(tǒng)中的應用十分廣泛,且ID引入了時間戳,基本上保持自增的。
@Data public class UserInfo { //指定主鍵生成策略使用雪花算法(默認策略) @TableId(type = IdType.ASSIGN_ID) private Long id; private String userName; private String passWord; }
2,ASSIGN_UUID(排除中劃線的UUID)
如果使用IdType.ASSIGN_UUID策略,并重新自動生成排除中劃線的UUID作為主鍵。主鍵類型為String,對應MySQL的表分段為VARCHAR(32)
提示:該策略使用接口IdentifierGenerator的方法nextUUID
@Data public class UserInfo { //指定主鍵生成策略為不含中劃線的UUID @TableId(type = IdType.ASSIGN_UUID) private String id; private String userName; private String passWord; }
3,AUTO(數(shù)據(jù)庫ID自增)
對于像MySQL這樣的支持主鍵自動遞增的數(shù)據(jù)庫,我們可以使用IdType.AUTO策略。
@Data public class UserInfo { //指定主鍵使用數(shù)據(jù)庫ID自增策略 @TableId(type = IdType.AUTO) private Integer id; private String userName; private String passWord; }
4,INPUT(插入前自行設置主鍵值)
(1)針對有序列的數(shù)據(jù)庫:Oracle,SQLServer等,當需要建立一個自增序列時,需要用到序列。
提示:
- 在Oracle 11g中,設置自增擴,需要先創(chuàng)建序列(SQUENCE)再創(chuàng)建一個觸發(fā)器(TRIGGER)。
- 在Oracle 12c中,只需要使用IDENTITY屬性就可以了,和MySQL一樣簡單。
(2)Mybatis -Plus已經(jīng)定義好了常見的數(shù)據(jù)庫主鍵序列,我們首先只需要在@Configuration類中定義好@Bean:Mybatis -Plus內置了如下數(shù)據(jù)庫主鍵序列(如果內置支持不滿足你的需求,可實現(xiàn)IKeyGenerator接口來進行擴展):
- DB2KeyGenerator
- H2KeyGenerator
- KingbaseKeyGenerator
- Oracle密鑰生成器
- PostgreKeyGenerator
@Bean public OracleKeyGenerator oracleKeyGenerator(){ return new OracleKeyGenerator(); }
提示:支持父類定義@KeySequence子類使用,這樣就可以幾個表共享一個Sequence
(3)然后實體類配置主鍵Sequence,指定主鍵策略為IdType.INPUT即可:
(4)如果主鍵是String類型的,也可以使用:如何使用序列作為主鍵,但是實體主鍵類型是字符串開頭,表的主鍵是varchar2,但是需要從序列中取值
@TableName("TEST_SEQUSER") @KeySequence("SEQ_TEST")//類注解 public class TestSequser{ @TableId(value = "ID", type = IdType.INPUT) private Long id; }
- 實體定義@KeySequence注解clazz指定類型String.class
- 實體定義主鍵的類型字符串
- 注意:oracle的序列返回的是Long類型,如果主鍵類型是Integer,可能會引起ClassCastException
@KeySequence(value = "SEQ_ORACLE_STRING_KEY", clazz = String.class) public class YourEntity{ @TableId(value = "ID_STR", type = IdType.INPUT) private String idStr; ... }
5,無(無狀態(tài))
如果使用IdType.NONE策略,表示未設置主鍵類型(注解里等于跟隨上下,左右里約等于INPUT)
附:變量策略配置
假設我們希望完全全部都使用AUTO策略(數(shù)據(jù)庫ID自增),那么可以在 application.properties中添加如下配置進行修改:
mybatis-plus.global-config.db-config.id-type=auto
參考資料
地址:https://www.hangge.com/blog/cache/detail_2904.html
到此這篇關于MybatisPlus 主鍵策略(type=IdType.ASSIGN_ID等詳解)的文章就介紹到這了,更多相關MybatisPlus 主鍵策略內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
以Spring Boot的方式顯示圖片或下載文件到瀏覽器的示例代碼
這篇文章主要介紹了以Spring Boot的方式顯示圖片或下載文件到瀏覽器的示例代碼,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01詳解用Kotlin寫一個基于Spring Boot的RESTful服務
這篇文章主要介紹了詳解用Kotlin寫一個基于Spring Boot的RESTful服務 ,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05Spring boot整合shiro+jwt實現(xiàn)前后端分離
這篇文章主要為大家詳細介紹了Spring boot整合shiro+jwt實現(xiàn)前后端分離,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-12-12