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

