
本文為mybatis系列檔案的第6篇,前5篇請訪問下面的網址,
- 小書MybatisPlus第1篇-整合SpringBoot快速開始增刪改查
- 小書MybatisPlus第2篇-條件構造器的應用及總結
- 小書MybatisPlus第3篇-自定義SQL
- 小書MybatisPlus第4篇-表格分頁與下拉分頁查詢
- 小書MybatisPlus第5篇-Active Record模式精講
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 = "https://www.cnblogs.com/zimug/p/SEQ_USER" , clazz = Long.class)
public class User {
@TableId(value = "https://www.cnblogs.com/zimug/p/ID",type = IdType.INPUT)
private Integer id;
歡迎關注我的博客,里面有很多精品合集
- 本文轉載注明出處(必須帶連接,不能只轉文字):字母哥博客,
覺得對您有幫助的話,幫我點贊、分享!您的支持是我不竭的創作動力! ,另外,筆者最近一段時間輸出了如下的精品內容,期待您的關注,
- 《手摸手教你學Spring Boot2.0》
- 《Spring Security-JWT-OAuth2一本通》
- 《實戰前后端分離RBAC權限管理系統》
- 《實戰SpringCloud微服務從青銅到王者》
- 《VUE深入淺出系列》
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/137676.html
標籤:Java
上一篇:自已動手作圖搞清楚AVL樹
