
* [小書MybatisPlus第1篇-整合SpringBoot快速開始增刪改查](http://www.zimug.com/other/springboot/%e5%b0%8f%e4%b9%a6mybatisplus%e7%ac%ac1%e7%af%87-%e6%95%b4%e5%90%88springboot%e5%bf%ab%e9%80%9f%e5%bc%80%e5%a7%8b%e5%a2%9e%e5%88%a0%e6%94%b9%e6%9f%a5/.html)
* [小書MybatisPlus第2篇-條件構造器的應用及總結](http://www.zimug.com/other/springboot/%e5%b0%8f%e4%b9%a6mybatisplus%e7%ac%ac2%e7%af%87-%e6%9d%a1%e4%bb%b6%e6%9e%84%e9%80%a0%e5%99%a8%e7%9a%84%e5%ba%94%e7%94%a8%e5%8f%8a%e6%80%bb%e7%bb%93/.html)
* [小書MybatisPlus第3篇-自定義SQL](http://www.zimug.com/other/java/%e5%b0%8f%e4%b9%a6mybatisplus%e7%ac%ac3%e7%af%87-%e8%87%aa%e5%ae%9a%e4%b9%89sql/.html)
* [小書MybatisPlus第4篇-表格分頁與下拉分頁查詢](http://www.zimug.com/other/springboot/%e5%b0%8f%e4%b9%a6mybatisplus%e7%ac%ac3%e7%af%87-%e8%a1%a8%e6%a0%bc%e5%88%86%e9%a1%b5%e4%b8%8e%e4%b8%8b%e6%8b%89%e5%88%86%e9%a1%b5%e6%9f%a5%e8%af%a2/.html)
* [小書MybatisPlus第5篇-Active Record模式精講](http://www.zimug.com/other/springboot/%e5%b0%8f%e4%b9%a6mybatisplus%e7%ac%ac5%e7%af%87-active-record%e6%a8%a1%e5%bc%8f%e7%b2%be%e8%ae%b2/.html)
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以后,主要有五種主鍵生成策略。
~~~java
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);
}
~~~
## 三、局部注解配置策略
我們針對主鍵設置主鍵策略使用注解方式為
~~~java
@TableId(type = IdType.AUTO)
private long userId;
~~~
## 四、全局配置策略
~~~cpp
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;
~~~