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

MybatisPlus 主鍵策略之type=IdType.ASSIGN_ID等詳解

 更新時間:2024年04月23日 09:41:29   作者:DN金猿  
雪花算法(雪花)是微博開源的分布式ID生成算法其核心思想就是:使用一個64位的長型的數(shù)字作為全局唯一ID,這篇文章主要介紹了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的方式顯示圖片或下載文件到瀏覽器的示例代碼

    這篇文章主要介紹了以Spring Boot的方式顯示圖片或下載文件到瀏覽器的示例代碼,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • java泛型基本知識及通用方法

    java泛型基本知識及通用方法

    這篇文章主要介紹了java泛型基礎知識及通用方法,從以下幾個方面介紹一下java的泛型: 基礎, 泛型關鍵字, 泛型方法, 泛型類和接口,感興趣的可以了解一下
    2019-04-04
  • 如何將maven項目導出jar包(最簡單方法)

    如何將maven項目導出jar包(最簡單方法)

    大家都知道對于將maven項目導出jar包有好幾種方式,本文給大家分享一種方式最容易且最方便,感興趣的朋友跟隨小編一起看看吧
    2023-11-11
  • Java實現(xiàn)石頭剪刀布游戲

    Java實現(xiàn)石頭剪刀布游戲

    這篇文章主要為大家詳細介紹了Java實現(xiàn)石頭剪刀布游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-10-10
  • Spring boot AOP通過XML配置文件聲明的方法

    Spring boot AOP通過XML配置文件聲明的方法

    這篇文章主要介紹了Spring boot AOP通過XML配置文件聲明,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-06-06
  • MapStruct Plus的使用教程

    MapStruct Plus的使用教程

    MapStruct和MapStructPlus是Java類型映射的工具,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-12-12
  • 聊聊關于Java方法重寫的反思

    聊聊關于Java方法重寫的反思

    最近在開發(fā)中遇到一個關于Java方法重寫的一些問題,對于方法重寫的用法以及可能導致的問題產生了一些思考,本文用于記錄下這些想法,希望對大家也有所幫助
    2023-05-05
  • java處理按鈕點擊事件的方法

    java處理按鈕點擊事件的方法

    下面小編就為大家?guī)硪黄猨ava處理按鈕點擊事件的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • 詳解用Kotlin寫一個基于Spring Boot的RESTful服務

    詳解用Kotlin寫一個基于Spring Boot的RESTful服務

    這篇文章主要介紹了詳解用Kotlin寫一個基于Spring Boot的RESTful服務 ,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • Spring boot整合shiro+jwt實現(xiàn)前后端分離

    Spring boot整合shiro+jwt實現(xiàn)前后端分離

    這篇文章主要為大家詳細介紹了Spring boot整合shiro+jwt實現(xiàn)前后端分離,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-12-12

最新評論