Mybatisplus主鍵生成策略算法解析
mybatisplus支持多種主鍵生成策略,默認采用認 ID_WORKER 即雪花算法
雪花算法
snowflflake是Twitter開源的分布式ID生成算法,結(jié)果是一個long型的ID。其核心思想是:使用41bit作為毫秒數(shù),10bit作為機器的ID(5個bit是數(shù)據(jù)中心,5個bit的機器ID),12bit作為毫秒內(nèi)的流水號(意味著每個節(jié)點在每毫秒可以產(chǎn)生 4096 個 ID),最后還有一個符號位,永遠是0??梢员WC幾乎全球唯一!
mybatisplus默認主鍵生成策略有可能會和我們的數(shù)據(jù)庫產(chǎn)生沖突,導(dǎo)致插入數(shù)據(jù)失??;當(dāng)遇到這種情況時,我們需要自己配置主鍵生成策略,在實體類對應(yīng)主鍵加注解
package com.yl.bean; import com.baomidou.mybatisplus.annotation.FieldFill; import com.baomidou.mybatisplus.annotation.IdType; import com.baomidou.mybatisplus.annotation.TableField; import com.baomidou.mybatisplus.annotation.TableId; import lombok.Data; import lombok.NoArgsConstructor; import java.io.Serializable; import java.util.Date; /** * 用戶實體類 */ @Data @NoArgsConstructor public class User implements Serializable { @TableId(type=IdType.AUTO)//配置主鍵 private Integer id; private String name; private Integer age; private String email; @TableField(fill = FieldFill.INSERT )//插入數(shù)據(jù)時更新該字段 private Date createTime; @TableField(fill = FieldFill.INSERT_UPDATE)//插入和修改時更新該字段 private Date updateTime; }
主鍵生成類型源碼解釋
public enum IdType {
AUTO(0), // 數(shù)據(jù)庫id自增,選擇這種類型數(shù)據(jù)庫表主鍵要設(shè)置為自增
NONE(1), // 未設(shè)置主鍵
INPUT(2), // 手動輸入
ID_WORKER(3), // 默認的全局唯一id
UUID(4), // 全局唯一id
uuid ID_WORKER_STR(5); //ID_WORKER 字符串表示法 }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaEE實現(xiàn)基于SMTP協(xié)議的郵件發(fā)送功能
這篇文章主要為大家詳細介紹了JavaEE實現(xiàn)基于SMTP協(xié)議的郵件發(fā)送功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-05-05SpringMVC用XML方式實現(xiàn)AOP的方法示例
這篇文章主要介紹了SpringMVC用XML方式實現(xiàn)AOP的方法示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04Java編程中使用JDBC API連接數(shù)據(jù)庫和創(chuàng)建程序的方法
這篇文章主要介紹了Java編程中使用JDBC API連接數(shù)據(jù)庫和創(chuàng)建程序的基本教程,JDBC是一種用于執(zhí)行SQL語句的Java API,可以為多種關(guān)系數(shù)據(jù)庫提供統(tǒng)一訪問需要的朋友可以參考下2015-12-12SpringCloud Ribbon與OpenFeign詳解如何實現(xiàn)服務(wù)調(diào)用
這篇文章主要介紹了SpringCloud Ribbon與OpenFeign實現(xiàn)服務(wù)調(diào)用的過程,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-09-09