您好,登錄后才能下訂單哦!
這篇文章主要介紹“MyBatisPlus之id生成策略怎么使用”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“MyBatisPlus之id生成策略怎么使用”文章能幫助大家解決問題。
不同的表的id:
日志:自增(1,2,3,4,……)
購物訂單:特殊規則(FQ23948AK3843)
外賣單:關聯地區日期等信息(10 04 20200314 34 91)
關系表:可省略id
……
不同的業務采用的ID生成方式應該是不一樣的,那么在MyBatisPlus(以下簡稱MP)中都提供了哪些主鍵生成策略,以及我們該如何進行選擇?
這里需要使用到一個注解 @TableId( type = id生成策略 ) ,將改注解加到實體類的id屬性上,如下:
@Data @TableName("tbl_user") public class User { @TableId(type = IdType.AUTO) private Long id; ... }
其中的id生成策略的取值來自枚舉類 IdType 如下:
從源碼中可以看到,公有如下幾種生成策略:
AUTO:id自增
NONE: 不設置id生成策略
INPUT:用戶手工輸入id
ASSIGN_ID:雪花算法生成id
ASSIGN_UUID:以UUID生成算法作為id生成策略
其他的幾個策略均已過時,都將被ASSIGN_ID和ASSIGN_UUID代替掉。
使用AUTO策略的時候一定要確保對應的數據庫表設置了ID主鍵自增,否則無效
另外,AUTO策略不能在分布式系統中使用,因為每臺數據庫服務器如果都基于本地的最新ID進行自增,那就會出現ID沖突
不設置id生成策略,MP不自動生成,約等于INPUT
這種ID生成策略,需要將表的自增策略刪除掉,然后手動設置ID值
void userSave(){ User user = new User(); //設置主鍵ID的值 user.setId(123456L); //為其他屬性賦值... userDao.insert(user); }
采用該策略時,如果用戶自己設置ID,MP會使用用戶設置的ID,如果用戶不自己設置ID值,那么MP會根據雪花算法自動生成ID,該策略可在分布式系統中使用
雪花算法:
雪花算法生成的是一個64bit大小的整數(對應Long)
時間戳:用來記錄時間戳,毫秒級
工作機器id:用來記錄工作機器id
序列號:占用12bit,每個節點每毫秒0開始不斷累加,最多可以累加到4095,一共可以產生4096個ID
從上面可以看出,ASSIGN_ID 生成的策略和服務器時間有關,如果修改了系統時間就有可能導致出現重復主鍵 ,這點需要注意
ASSIGN_UUID是自動生成一個不重復的、長度為32位的字符串,也能在分布式系統中使用
因此使用ASSIGN_UUID時需要注意:
實體類的主鍵類型不能是Long,而應該改成String類型
表中的主鍵類型設置為varchar,長度要大于32,如果長度小的話就會導致插入失敗
ASSIGN_UUID的缺點比較明顯:生成的主鍵是32位的字符串,長度過長占用空間而且還不能排序,查詢性能也慢
關于“MyBatisPlus之id生成策略怎么使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。