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