主鍵策略
mybatis-plus3.3.0以后,主要有五種主鍵生成策略
AUTO (自動增長策略)
aout自動增長策略,這個配合數(shù)據(jù)庫使用,mysql可以,但是oracle不行。
使用方法
在主鍵字段上加上 @TableId(type = IdType.AUTO)
@Data
public class UserInfo {
//指定主鍵使用數(shù)據(jù)庫ID自增策略
@TableId(type = IdType.AUTO)
private Integer id;
private String userName;
private String passWord;
}
Input(自定義輸入策略)
自定義輸入策略
Mybatis-Plus 內(nèi)置了如下數(shù)據(jù)庫主鍵序列(如果內(nèi)置支持不滿足你的需求,可實現(xiàn) IKeyGenerator 接口來進行擴展):
DB2KeyGenerator
H2KeyGenerator
KingbaseKeyGenerator
OracleKeyGenerator
PostgreKeyGenerator
使用方法
首先添加@Bean
@Bean
public OracleKeyGenerator oracleKeyGenerator(){
return new OracleKeyGenerator();
}
然后實體類配置主鍵 Sequence,指定主鍵策略為 IdType.INPUT 即可,
@Data
@KeySequence(value = "SEQ_ACL_ROLE" , clazz = Integer.class)
public class AclUser implements Serializable {
private static final long serialVersionUID = 780903014942735924L;
@TableId(value = "ID",type = IdType.INPUT)
private Integer id;
ASSIGN_ID(雪花算法)
如果不設(shè)置 type 值,默認(rèn)則使用 IdType.ASSIGN_ID 策略(自 3.3.0 起)。該策略會使用雪花算法自動生成主鍵 ID,主鍵類型為 Long 或 String。
雪花算法(SnowFlake)是 Twitter 開源的分布式 id 生成算法。其核心思想就是:使用一個 64 bit 的 long 型的數(shù)字作為全局唯一 id。在分布式系統(tǒng)中的應(yīng)用十分廣泛,且 ID 引入了時間戳,基本上保持自增的
使用方法
指定主鍵生成策略使用雪花算法(默認(rèn)策略)
@Data
public class UserInfo {
//指定主鍵生成策略使用雪花算法(默認(rèn)策略)
@TableId(type = IdType.ASSIGN_ID)
private Long id;
private String userName;
private String passWord;
}
ASSIGN_UUID(不含中劃線的UUID)
如果使用 IdType.ASSIGN_UUID 策略,則會自動生成不含中劃線的 UUID 作為主鍵,主鍵類型為 String。
使用方法
@Data
public class UserInfo {
//指定主鍵生成策略為不含中劃線的UUID
@TableId(type = IdType.ASSIGN_UUID)
private String id;
private String userName;
private String passWord;
}
NONE(無狀態(tài))
如果使用 IdType.NONE 策略,表示未設(shè)置主鍵類型(注解里等于跟隨全局,全局里約等于 INPUT)
假設(shè)我們希望默認(rèn)全部都使用 AUTO 策略(數(shù)據(jù)庫 ID 自增),那么可以在 application.properties 中添加如下配置進行修改:文章來源:http://www.zghlxwxcb.cn/news/detail-684021.html
mybatis-plus.global-config.db-config.id-type=auto文章來源地址http://www.zghlxwxcb.cn/news/detail-684021.html
到了這里,關(guān)于Mybatis-plus 主鍵生成策略的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!