亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

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

    java泛型基本知識(shí)及通用方法

    這篇文章主要介紹了java泛型基礎(chǔ)知識(shí)及通用方法,從以下幾個(gè)方面介紹一下java的泛型: 基礎(chǔ), 泛型關(guān)鍵字, 泛型方法, 泛型類(lèi)和接口,感興趣的可以了解一下
    2019-04-04
  • 如何將maven項(xiàng)目導(dǎo)出jar包(最簡(jiǎn)單方法)

    如何將maven項(xiàng)目導(dǎo)出jar包(最簡(jiǎn)單方法)

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

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

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

    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
  • MapStruct Plus的使用教程

    MapStruct Plus的使用教程

    MapStruct和MapStructPlus是Java類(lèi)型映射的工具,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-12-12
  • 聊聊關(guān)于Java方法重寫(xiě)的反思

    聊聊關(guān)于Java方法重寫(xiě)的反思

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

    java處理按鈕點(diǎn)擊事件的方法

    下面小編就為大家?guī)?lái)一篇java處理按鈕點(diǎn)擊事件的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-04-04
  • 詳解用Kotlin寫(xiě)一個(gè)基于Spring Boot的RESTful服務(wù)

    詳解用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)前后端分離

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

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

最新評(píng)論