小書MybatisPlus第6篇-主鍵生成策略精講


本文為mybatis系列文檔的第6篇,前5篇請訪問下面的網址。

Mybatis Plus 為我們提供了三種設置 主鍵生成策略的方式。它們的優先級順序是:局部注解 > 全局 > 默認(雪花算法)。下面我們來一一介紹

一、默認主鍵生成策略:雪花算法

Mybatis Plus如果不做任何主鍵策略配置,默認使用的是雪花算法。該策略會根據雪花算法生成主鍵ID,主鍵類型為Long或String(具體到MySQL數據庫就是BIGINT和VARCHAR),該策略使用接口IdentifierGenerator的方法nextId(默認實現類為DefaultIdentifierGenerator雪花算法)

snowflake算法是Twitter開源的分布式ID生成算法,結果是一個long類型的ID 。其核心思想:使用41bit作為毫秒數,10bit作為機器的ID(5bit數據中心,5bit的機器ID),12bit作為毫秒內的流水號(意味着每個節點在每個毫秒可以產生4096個ID),最后還有一個符號位,永遠是0。

二、自定義主鍵策略

mybatis-plus3.3.0以后,主要有五種主鍵生成策略。

public enum IdType {
    /**
     * 數據庫ID自增,數據庫需要支持主鍵自增(如MySQL),並設置主鍵自增
     */
    AUTO(0),

    /**
     * 該類型為未設置主鍵類型,默認使用雪花算法生成
     */
    NONE(1),

    /**
     * 用戶輸入ID,數據類型和數據庫保持一致就行
     * <p>該類型可以通過自己注冊自動填充插件進行填充</p>
     */
    INPUT(2),

    /* 以下3種類型、只有當插入對象ID 為空,才自動填充。 */
    /**
     * 全局唯一ID (idWorker),數值類型  數據庫中也必須是數值類型 否則會報錯
     */
    ID_WORKER(3),
    /**
     * 全局唯一ID (UUID,不含中划線)
     */
    UUID(4),
    /**
     * 字符串全局唯一ID (idWorker 的字符串表示),數據庫也要保證一樣字符類型
     */
    ID_WORKER_STR(5);
}

三、局部注解配置策略

我們針對主鍵設置主鍵策略使用注解方式為

@TableId(type = IdType.AUTO)
private long userId;

四、全局配置策略

mybatis-plus:
  global-config:
    db-config:
      id-type: auto

五、擴展使用

5.1.INPUT用戶輸入ID策略的用法

其中需要和大家特殊介紹的是:Input(用戶輸入ID),這個ID來源可以有兩種

  • 用戶自己設置ID,並在insert之前SET主鍵的值
  • 一些有序列的數據庫,比如Oracle,SQLServer等,針對這些數據庫我們可以通過序列填充ID字段

Mybatis-Plus 內置了如下數據庫主鍵序列(如果內置支持不滿足你的需求,可實現 IKeyGenerator 接口來進行擴展):

  • DB2KeyGenerator
  • H2KeyGenerator
  • KingbaseKeyGenerator
  • OracleKeyGenerator
  • PostgreKeyGenerator

以Oracle 的Sequence使用方法為例,使用方法如下:
首先添加@Bean

 @Bean
    public OracleKeyGenerator oracleKeyGenerator(){
        return new OracleKeyGenerator();
    }

然后實體類配置主鍵 Sequence,指定主鍵策略為 IdType.INPUT 即可,

@Data
@KeySequence(value = "SEQ_USER" , clazz = Long.class)
public class User {

    @TableId(value = "ID",type = IdType.INPUT)
    private Integer id;

歡迎關注我的博客,里面有很多精品合集

  • 本文轉載注明出處(必須帶連接,不能只轉文字):字母哥博客

覺得對您有幫助的話,幫我點贊、分享!您的支持是我不竭的創作動力! 。另外,筆者最近一段時間輸出了如下的精品內容,期待您的關注。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM