本文爲mybatis系列文檔的第6篇,前5篇請訪問下面的網址。html
Mybatis Plus 爲咱們提供了三種設置 主鍵生成策略的方式。它們的優先級順序是:局部註解 > 全局 > 默認(雪花算法)。下面咱們來一一介紹vue
Mybatis Plus若是不作任何主鍵策略配置,默認使用的是雪花算法。該策略會根據雪花算法生成主鍵ID,主鍵類型爲Long或String(具體到MySQL數據庫就是BIGINT和VARCHAR),該策略使用接口IdentifierGenerator的方法nextId(默認實現類爲DefaultIdentifierGenerator雪花算法)java
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); }
咱們針對主鍵設置主鍵策略使用註解方式爲spring
@TableId(type = IdType.AUTO) private long userId;
mybatis-plus: global-config: db-config: id-type: auto
其中須要和你們特殊介紹的是:Input(用戶輸入ID),這個ID來源能夠有兩種sql
Mybatis-Plus 內置了以下數據庫主鍵序列(若是內置支持不知足你的需求,可實現 IKeyGenerator 接口來進行擴展):數據庫
以Oracle 的Sequence使用方法爲例,使用方法以下:
首先添加@Bean後端
@Bean public OracleKeyGenerator oracleKeyGenerator(){ return new OracleKeyGenerator(); }
而後實體類配置主鍵 Sequence,指定主鍵策略爲 IdType.INPUT 便可,springboot
@Data @KeySequence(value = "SEQ_USER" , clazz = Long.class) public class User { @TableId(value = "ID",type = IdType.INPUT) private Integer id;
以爲對您有幫助的話,幫我點贊、分享!您的支持是我不竭的創做動力! 。另外,筆者最近一段時間輸出了以下的精品內容,期待您的關注。mybatis