目錄
1.1、為什么選擇不同的id生成策略
1.2、策略種類
1.2.1、AUTO(自動增長策略)
1.2.3、ASSIGN_ID(雪花算法)
1.2.4、ASSIGN_UUID(不含中劃線的UUID)
1.2.5、NONE(無狀態(tài))
1.3、注意
1.1、為什么選擇不同的id生成策略
1、Mybatis-plus提供了多種主鍵生成策略, 可以在Pojo類中主鍵上加注解進行配置,例如數(shù)據(jù)庫主鍵自增 @TableId(type=IdType.AUTO)
2、不同的表應用不同的id生成策略:
- 日志:自增(1,2,3,4,……)
- 購物訂單:特殊規(guī)則(FQ23948AK3843)
- 外賣單:關聯(lián)地區(qū)日期等信息(10 04 20200314 34 91)
- 關系表:可省略id
- ……
3、表現(xiàn)形式
- 名稱 @TableId
- 類型 屬性注解
- 位置 模型類中用于表示主鍵的屬性定義上方
- 作用 設置當前類中主鍵屬性的生成策略
- 相關屬性
- value(默認):設置數(shù)據(jù)庫表主鍵名稱
- type:設置主鍵屬性的生成策略,值參照IdType的枚舉值
1.2、策略種類
1.2.1、AUTO(自動增長策略)
AUTO
自動增長策略,這個配合數(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;
}
1.2.2、Input(自定義輸入策略)
自定義輸入策略:如果不想使用數(shù)據(jù)庫的自增主鍵,也可以使用INPUT進行自己傳遞主鍵即可,進行插入工作,但在插入之前一定要檢查數(shù)據(jù)庫是否已經存在了該主鍵。
Mybatis-Plus 內置了如下數(shù)據(jù)庫主鍵序列:
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;
1.2.3、ASSIGN_ID(雪花算法)
如果不設置type值,默認則使用IdType.ASSIGN_ID策略(自 3.3.0 起)。該策略會使用雪花算法自動生成主鍵 ID,主鍵類型為 Long 或 String。
雪花算法(SnowFlake)是 Twitter 開源的分布式 id 生成算法。其核心思想就是:使用一個 64 bit 的 long 型的數(shù)字作為全局唯一 id。在分布式系統(tǒng)中的應用十分廣泛,且 ID 引入了時間戳,基本上保持自增的。
使用方法
指定主鍵生成策略使用雪花算法(默認策略)
@Data
public class UserInfo {
//指定主鍵生成策略使用雪花算法(默認策略)
@TableId(type = IdType.ASSIGN_ID)
private Long id;
private String userName;
private String passWord;
}
1.2.4、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;
}
1.2.5、NONE(無狀態(tài))
如果使用?IdType.NONE
?策略,表示未設置主鍵類型(注解里等于跟隨全局,全局里約等于?INPUT
)
假設我們希望默認全部都使用?AUTO?
策略(數(shù)據(jù)庫ID
自增),那么可以在?application.properties?
中添加如下配置進行修改:文章來源:http://www.zghlxwxcb.cn/news/detail-424911.html
mybatis-plus.global-config.db-config.id-type=auto
1.3、注意
注意事項:Mysql?
的默認值只有在insert
語句中沒有這個字段時才會生效,如果insert
中有插入該字段而該字段取值又為null
,null
值將被插入到表中,默認值此時失效。使用Mybatis
操作也是一樣的道理,只要這個實體里面含有這個字段,并且值為null,則不會插入默認值。文章來源地址http://www.zghlxwxcb.cn/news/detail-424911.html
到了這里,關于Mybatis-plus id生成策略的文章就介紹完了。如果您還想了解更多內容,請在右上角搜索TOY模板網以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持TOY模板網!