MybatisPlus 主鍵策略的幾種實現(xiàn)方法
MybatisPlus-Plus提供了多種主鍵生成策略,我們可以通過@TableId注解的 類型屬性來設(shè)置主鍵id的增長策略,一共有幾個多個主鍵策略,可根據(jù)情況自由配置。
主鍵策略
1、AUTO(自動增長策略)
AUTO自動增長策略,對于像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; }
2、INPUT(插入前自行設(shè)置主鍵值)
自定義輸入策略:如果不想使用數(shù)據(jù)庫的自增主鍵,也可以使用INPUT進行自己傳遞主鍵即可,進行插入工作,但在插入之前一定要檢查數(shù)據(jù)庫是否已經(jīng)存在了該主鍵。
(1)針對有序列的數(shù)據(jù)庫:Oracle,SQLServer等,當(dāng)需要建立一個自增序列時,需要用到序列。
提示:
在Oracle 11g中,設(shè)置自增擴,需要先創(chuàng)建序列(SQUENCE)再創(chuàng)建一個觸發(fā)器(TRIGGER)。
在Oracle 12c中,只需要使用IDENTITY屬性就可以了,和MySQL一樣簡單。
(2)Mybatis-Plus已經(jīng)定義好了常見的數(shù)據(jù)庫主鍵序列,我們首先只需要在@Configuration類中定義好@Bean:Mybatis -Plus內(nèi)置了如下數(shù)據(jù)庫主鍵序列(如果內(nèi)置支持不滿足你的需求,可實現(xiàn)IKeyGenerator接口來進行擴展):
DB2KeyGenerator
H2KeyGenerator
KingbaseKeyGenerator
OracleKeyGenerator
PostgreKeyGenerator
(3)然后實體類配置主鍵 Sequence,指定主鍵策略為IdType.INPUT即可:
@Data @KeySequence(value = "SEQ_ACL_ROLE" , clazz = Integer.class) public class AclUser implements Serializable { private static final long serialVersionUID = 780903014942735924L; @TableId(value = "ID",type = IdType.INPUT) private Integer id;
3、ASSING_ID(雪花算法)
如果不設(shè)置類型值,默認則使用IdType.ASSIGN_ID策略(自3.3.0起)。該策略會使用雪花算法自動生成主鍵ID,主鍵類型為Long或String(分別對應(yīng)的MySQL的表字段為BIGINT和VARCHAR)
雪花算法(SnowFlake)是 Twitter 開源的分布式 id 生成算法。其核心思想就是:使用一個 64 bit 的 long 型的數(shù)字作為全局唯一 id。在分布式系統(tǒng)中的應(yīng)用十分廣泛,且 ID 引入了時間戳,基本上保持自增的。
@Data public class UserInfo { //指定主鍵生成策略使用雪花算法(默認策略) @TableId(type = IdType.ASSIGN_ID) private Long id; private String userName; private String passWord; }
4、ASSING_UUID(不含中劃線的UUID)
如果使用IdType.ASSIGN_UUID策略,并重新自動生成排除中劃線的UUID作為主鍵。主鍵類型為String,對應(yīng)MySQL的表分段為VARCHAR(32)
@Data public class UserInfo { //指定主鍵生成策略為不含中劃線的UUID @TableId(type = IdType.ASSIGN_UUID) private String id; private String userName; private String passWord; }
5、NONE(無狀態(tài))
如果使用 IdType.NONE 策略,表示未設(shè)置主鍵類型(注解里等于跟隨全局,全局里約等于 INPUT)
雪花算法
算法介紹
雪花算法的原理就是生成一個的 64 位比特位的 long 類型的唯一 id。
1.最高 1 位固定值 0,因為生成的 id 是正整數(shù),如果是 1 就是負數(shù)了。
2.接下來 41 位存儲毫秒級時間戳,2^41/(1000*60*60*24*365)=69,大概可以使用 69 年。
3.再接下 10 位存儲機器碼,包括 5 位 datacenterId 和 5 位 workerId。最多可以部署 2^10=1024 臺機器。
4.最后 12 位存儲序列號。同一毫秒時間戳?xí)r,通過這個遞增的序列號來區(qū)分。即對于同一臺機器而言,同一毫秒時間戳下,可以生成 2^12=4096 個不重復(fù) id。
可以將雪花算法作為一個單獨的服務(wù)進行部署,然后需要全局唯一 id 的系統(tǒng),請求雪花算法服務(wù)獲取id 即可。
對于每一個雪花算法服務(wù),需要先指定 10 位的機器碼,這個根據(jù)自身業(yè)務(wù)進行設(shè)定即可。例如機房號+機器號,機器號+服務(wù)號,或者是其他可區(qū)別標識的 10 位比特位的整數(shù)值都行。
算法優(yōu)缺點
優(yōu)點:
高并發(fā)分布式環(huán)境下生成不重復(fù) id,每秒可生成百萬個不重復(fù) id。
基于時間戳,以及同一時間戳下序列號自增,基本保證 id 有序遞增。
不依賴第三方庫或者中間件。
算法簡單,在內(nèi)存中進行,效率高。
缺點:
依賴服務(wù)器時間,服務(wù)器時鐘回撥時可能會生成重復(fù) id。算法中可通過記錄最后一個生成 id 時的時間戳來解決,每次生成 id 之前比較當(dāng)前服務(wù)器時鐘是否被回撥,避免生成重復(fù) id。
到此這篇關(guān)于MybatisPlus 主鍵策略的幾種實現(xiàn)方法的文章就介紹到這了,更多相關(guān)MybatisPlus 主鍵策略內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot中Formatter和Converter用法和區(qū)別小結(jié)
本文主要介紹了SpringBoot中Formatter和Converter用法和區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07Mybatis實現(xiàn)分包定義數(shù)據(jù)庫的原理與過程
這篇文章主要給大家介紹了關(guān)于Mybatis實現(xiàn)分包定義數(shù)據(jù)庫的原理與過程,文中通過實例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2022-01-01Java Scanner的使用和hasNextXXX()的用法說明
這篇文章主要介紹了Java Scanner的使用和hasNextXXX()的用法說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-10-10Java分頁簡介_動力節(jié)點Java學(xué)院整理
這篇文章主要為大家詳細介紹了Java分頁簡介的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08