欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mybatis-plus邏輯刪除與唯一約束沖突問題

 更新時間:2023年11月27日 11:28:04   作者:今天你寫代碼了嗎??  
本文探討了MyBatis-Plus邏輯刪除與唯一約束沖突的問題,分析了產生沖突的原因,并提出了解決方案,具有一定的參考價值,感興趣的可以了解一下

問題描述:

在使用mybatis-plus進行數(shù)據(jù)庫的增刪查改的時候,我們一般都會設置用戶名為唯一索引(為什么?因為用戶名肯定不能重復)

當?shù)谝淮涡略鲇脩魰r,會在數(shù)據(jù)庫插入一條用戶數(shù)據(jù):能插入成功代表用戶名不重復:
關心這兩個字段:

  • username:zhangsan
  • is_deleted:0 (未刪除狀態(tài))

此時的數(shù)據(jù)庫用的username唯一索引:

那么當這個用戶被刪除的時候:

is_deleted:1 (刪除狀態(tài))

此時當再次添加用戶名為zhangsan的用戶的時候就會觸發(fā)唯一索引添加數(shù)據(jù)失敗的情況(為什么呢,因為刪除的用戶數(shù)據(jù)在數(shù)據(jù)庫里面使用的是改變is_deletd字段的值來表示的邏輯刪除,用戶數(shù)據(jù)其實還是存在數(shù)據(jù)庫的,當添加用戶的時候用戶名和已刪除的用戶的用戶名重復還是會觸發(fā)唯一索引沖突)

Duplicate entry ‘重復的用戶名’ for key ‘sys_user.idx_username’

解決方案

方案一 :直接刪除

在刪除用戶數(shù)據(jù)的時候不使用邏輯刪除,而是直接刪除用戶數(shù)據(jù)

結果:直接刪除數(shù)據(jù),不符合假刪除邏輯,不推薦

方案二:設置聯(lián)合唯一索引

字段的唯一約束,改為字段.與刪除標記字段的聯(lián)合唯一約束
通過設置username和is_deleted聯(lián)合唯一索引

這樣當刪除數(shù)據(jù)的時候,將數(shù)據(jù)的is_deleted字段為1,再次添加相同用戶名的數(shù)據(jù)時,會判斷是否存在username重復并且is_deleted = 0(添加數(shù)據(jù)的時候默認為0) 的數(shù)據(jù)(因為此時刪除的數(shù)據(jù)is_deleted = 1) 所以可以正常添加數(shù)據(jù)。

那么再次添加用戶名重復的數(shù)據(jù)(未刪除)的時候會再次觸發(fā)唯一索引

Duplicate entry '重復用戶名-0' for key ‘sys_user.idx_username’

注意:(可以忽略上面的使用username和is_deleted字段做唯一索引的做法)

上面這樣還會出現(xiàn)一個問題,當再次刪除數(shù)據(jù)的時候(此時數(shù)據(jù)庫表中已經有刪除的遺留數(shù)據(jù)),username和is_deleted聯(lián)合唯一索引還是會重復,如圖表示:

問題解決方案:

參考鏈接:邏輯刪除和唯一約束沖突的解決方案

此時可以追加一個刪除記錄字段,默認為1

此時聯(lián)合唯一索引為:

第一次添加數(shù)據(jù)的時候,deleteAt默認為1
第二次添加相同用戶名數(shù)據(jù)會觸發(fā)唯一索引(username相同 并且deleteAt=1)

第一次刪除數(shù)據(jù)的時候,給deleteAt字段設置當前時間戳,然后再刪除數(shù)據(jù)

第三次添加和刪除用戶相同用戶名的數(shù)據(jù)時,可以正常添加
第二次刪除數(shù)據(jù)的時候因為時間戳設置的不同,可以正常刪除

到此這篇關于mybatis-plus邏輯刪除與唯一約束沖突問題的文章就介紹到這了,更多相關mybatis-plus邏輯刪除與唯一約束沖突內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Java實現(xiàn)萬年歷效果

    Java實現(xiàn)萬年歷效果

    這篇文章主要為大家詳細介紹了Java實現(xiàn)萬年歷效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • 2021年最新Redis面試題匯總(4)

    2021年最新Redis面試題匯總(4)

    在程序員面試過程中redis相關的知識是常被問到的話題。這篇文章主要介紹了幾道Redis面試題,整理一下分享給大家,感興趣的小伙伴們可以參考一下
    2021-07-07
  • Java中日期格式化YYYY-DD的操作bug

    Java中日期格式化YYYY-DD的操作bug

    這篇文章主要介紹了Java中日期格式化YYYY-DD中遇到的坑,本文給大家分享到腳本之家平臺,需要的朋友可以參考下
    2020-01-01
  • SpringBoot3利用AOP實現(xiàn)IP黑名單功能

    SpringBoot3利用AOP實現(xiàn)IP黑名單功能

    在Web應用開發(fā)中,控制對特定IP地址的訪問權限是一個常見的需求,通過實現(xiàn)IP黑白名單功能,我們可以允許某些IP地址訪問應用,同時拒絕其他IP地址的訪問,本文將詳細介紹SpringBoot3利用AOP實現(xiàn)IP黑名單功能,并附上相應的代碼片段,需要的朋友可以參考下
    2024-09-09
  • SpringBoot使用Maven實現(xiàn)多環(huán)境配置管理

    SpringBoot使用Maven實現(xiàn)多環(huán)境配置管理

    軟件開發(fā)中經常有開發(fā)環(huán)境、測試環(huán)境、生產環(huán)境,而且一般這些環(huán)境配置會各不相同,本文主要介紹了SpringBoot使用Maven實現(xiàn)多環(huán)境配置管理,感興趣的可以了解一下
    2024-01-01
  • Swagger實現(xiàn)動態(tài)條件注入與全局攔截功能詳細流程

    Swagger實現(xiàn)動態(tài)條件注入與全局攔截功能詳細流程

    這篇文章主要介紹了Swagger實現(xiàn)動態(tài)條件注入與全局攔截功能詳細流程,Swagger 可以提供 API 操作的測試文檔,本文記錄 Swagger 使用過程中遇到的小問題
    2023-01-01
  • 詳解Java線程中斷知識點

    詳解Java線程中斷知識點

    在本篇文章中我們給大家分享了關于Java線程中斷的相關知識點內容以及相關代碼實例,有興趣的朋友們可以學習下。
    2018-09-09
  • JPA之EntityManager踩坑及解決:更改PersistenceContext

    JPA之EntityManager踩坑及解決:更改PersistenceContext

    這篇文章主要介紹了JPA之EntityManager踩坑及解決:更改PersistenceContext方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • 從面試中的問題分析ThreadLocal

    從面試中的問題分析ThreadLocal

    這篇文章主要介紹了從面試中的問題分析ThreadLocal,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,下面我們來一起學習一下吧
    2019-06-06
  • Java冒泡排序及優(yōu)化介紹

    Java冒泡排序及優(yōu)化介紹

    大家好,本篇文章主要講的是Java冒泡排序及優(yōu)化介紹,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12

最新評論