欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MyBatisPlus之id生成策略的方法

 更新時間:2023年03月17日 15:55:59   作者:Fearless____  
本文主要介紹了MyBatisPlus之id生成策略的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

一、為什么需要選擇不同的id生成策略

不同的表的id:

日志:自增(1,2,3,4,……)

購物訂單:特殊規(guī)則(FQ23948AK3843)

外賣單:關(guān)聯(lián)地區(qū)日期等信息(10 04 20200314 34 91)

關(guān)系表:可省略id

……

不同的業(yè)務(wù)采用的ID生成方式應(yīng)該是不一樣的,那么在MyBatisPlus(以下簡稱MP)中都提供了哪些主鍵生成策略,以及我們該如何進(jìn)行選擇?  

二、如何使用MP的id生成策略

這里需要使用到一個注解 @TableId( type = id生成策略 ) ,將改注解加到實體類的id屬性上,如下:

@Data
@TableName("tbl_user")
public class User {
 
    @TableId(type = IdType.AUTO)
    private Long id;
 
    ...
 
}

其中的id生成策略的取值來自枚舉類 IdType 如下:

 從源碼中可以看到,公有如下幾種生成策略:

  • AUTO:id自增
  • NONE: 不設(shè)置id生成策略
  • INPUT:用戶手工輸入id
  • ASSIGN_ID:雪花算法生成id
  • ASSIGN_UUID:以UUID生成算法作為id生成策略
  • 其他的幾個策略均已過時,都將被ASSIGN_ID和ASSIGN_UUID代替掉。

 AUTO

使用AUTO策略的時候一定要確保對應(yīng)的數(shù)據(jù)庫表設(shè)置了ID主鍵自增,否則無效

另外,AUTO策略不能在分布式系統(tǒng)中使用,因為每臺數(shù)據(jù)庫服務(wù)器如果都基于本地的最新ID進(jìn)行自增,那就會出現(xiàn)ID沖突

NONE

不設(shè)置id生成策略,MP不自動生成,約等于INPUT

INPUT

這種ID生成策略,需要將表的自增策略刪除掉,然后手動設(shè)置ID值

    void userSave(){
        User user = new User();
        //設(shè)置主鍵ID的值
        user.setId(123456L);
        
        //為其他屬性賦值...
 
        userDao.insert(user);
    }

ASSIGN_ID

采用該策略時,如果用戶自己設(shè)置ID,MP會使用用戶設(shè)置的ID,如果用戶不自己設(shè)置ID值,那么MP會根據(jù)雪花算法自動生成ID,該策略可在分布式系統(tǒng)中使用

雪花算法:

雪花算法生成的是一個64bit大小的整數(shù)(對應(yīng)Long)

時間戳:用來記錄時間戳,毫秒級

工作機(jī)器id:用來記錄工作機(jī)器id

序列號:占用12bit,每個節(jié)點每毫秒0開始不斷累加,最多可以累加到4095,一共可以產(chǎn)生4096個ID

從上面可以看出,ASSIGN_ID 生成的策略和服務(wù)器時間有關(guān),如果修改了系統(tǒng)時間就有可能導(dǎo)致出現(xiàn)重復(fù)主鍵 ,這點需要注意

ASSIGN_UUID

ASSIGN_UUID是自動生成一個不重復(fù)的、長度為32位的字符串,也能在分布式系統(tǒng)中使用

因此使用ASSIGN_UUID時需要注意:

  • 實體類的主鍵類型不能是Long,而應(yīng)該改成String類型
  • 表中的主鍵類型設(shè)置為varchar,長度要大于32,如果長度小的話就會導(dǎo)致插入失敗

ASSIGN_UUID的缺點比較明顯:生成的主鍵是32位的字符串,長度過長占用空間而且還不能排序,查詢性能也慢

到此這篇關(guān)于MyBatisPlus之id生成策略的方法的文章就介紹到這了,更多相關(guān)MyBatisPlus id生成策略內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java  工廠方法詳解及實例代碼

    java 工廠方法詳解及實例代碼

    這篇文章主要介紹了java 工廠方法詳解及實例代碼的相關(guān)資料,需要的朋友可以參考下
    2017-01-01
  • IDEA在plugins里搜不到mybatisx插件的解決方法

    IDEA在plugins里搜不到mybatisx插件的解決方法

    本文主要介紹了IDEA在plugins里搜不到mybatisx插件的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • Java微信授權(quán)登陸的實現(xiàn)示例

    Java微信授權(quán)登陸的實現(xiàn)示例

    微信授權(quán)登錄,官方文檔寫的比較簡潔。所以對于會的人一目了然,而對于新手剛?cè)腴T的人來說是舉步維艱。本文詳細(xì)的介紹了Java微信授權(quán)登陸的實現(xiàn)示例,感興趣的朋友可以了解一下
    2021-06-06
  • Springboot中MyBatisplus使用IPage和Page分頁的實例代碼

    Springboot中MyBatisplus使用IPage和Page分頁的實例代碼

    這篇文章主要介紹了Springboot中MyBatisplus使用IPage和Page分頁,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12
  • Spring使用注解存儲和讀取對象詳解

    Spring使用注解存儲和讀取對象詳解

    這篇文章主要給大家介紹了關(guān)于Spring如何通過注解存儲和讀取對象的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),有一定的參考價值,需要的朋友可以參考下
    2023-04-04
  • Java 重載、重寫、構(gòu)造函數(shù)的實例詳解

    Java 重載、重寫、構(gòu)造函數(shù)的實例詳解

    這篇文章主要介紹了Java 重載、重寫、構(gòu)造函數(shù)的實例詳解的相關(guān)資料,希望通過本文大家能理解掌握java 面向?qū)ο蟮姆椒?,需要的朋友可以參考?/div> 2017-09-09
  • 使用SpringBoot AOP 記錄操作日志、異常日志的過程

    使用SpringBoot AOP 記錄操作日志、異常日志的過程

    這篇文章主要介紹了使用SpringBoot AOP 記錄操作日志、異常日志的過程,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-05-05
  • Java中List刪除元素的幾種方法總結(jié)推薦

    Java中List刪除元素的幾種方法總結(jié)推薦

    這篇文章主要給大家介紹了關(guān)于Java中List刪除元素的幾種方法總結(jié),相信大家在日常的開發(fā)過程中,經(jīng)常需要對List或Map里面的符合某種業(yè)務(wù)的數(shù)據(jù)進(jìn)行刪除,需要的朋友可以參考下
    2023-10-10
  • Java基于TCP方式的二進(jìn)制文件傳輸

    Java基于TCP方式的二進(jìn)制文件傳輸

    這篇文章主要為大家介紹了Java基于TCP方式的二進(jìn)制文件傳輸,一個基于Java Socket協(xié)議之上文件傳輸?shù)耐暾纠?,基于TCP通信完成,感興趣的小伙伴們可以參考一下
    2016-01-01
  • 淺談Java中Lambda表達(dá)式的相關(guān)操作

    淺談Java中Lambda表達(dá)式的相關(guān)操作

    java8新特性,Lambda是一個匿名函數(shù),類似Python中的Lambda表達(dá)式、js中的箭頭函數(shù),目的簡化操作,文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下
    2021-06-06

最新評論