mybatis-plus邏輯刪除與唯一約束沖突問(wèn)題
問(wèn)題描述:
在使用mybatis-plus進(jìn)行數(shù)據(jù)庫(kù)的增刪查改的時(shí)候,我們一般都會(huì)設(shè)置用戶名為唯一索引(為什么?因?yàn)橛脩裘隙ú荒苤貜?fù))
當(dāng)?shù)谝淮涡略鲇脩魰r(shí),會(huì)在數(shù)據(jù)庫(kù)插入一條用戶數(shù)據(jù):能插入成功代表用戶名不重復(fù):
關(guān)心這兩個(gè)字段:
- username:zhangsan
- is_deleted:0 (未刪除狀態(tài))
此時(shí)的數(shù)據(jù)庫(kù)用的username唯一索引:
那么當(dāng)這個(gè)用戶被刪除的時(shí)候:
is_deleted:1 (刪除狀態(tài))
此時(shí)當(dāng)再次添加用戶名為zhangsan的用戶的時(shí)候就會(huì)觸發(fā)唯一索引添加數(shù)據(jù)失敗的情況(為什么呢,因?yàn)閯h除的用戶數(shù)據(jù)在數(shù)據(jù)庫(kù)里面使用的是改變is_deletd字段的值來(lái)表示的邏輯刪除,用戶數(shù)據(jù)其實(shí)還是存在數(shù)據(jù)庫(kù)的,當(dāng)添加用戶的時(shí)候用戶名和已刪除的用戶的用戶名重復(fù)還是會(huì)觸發(fā)唯一索引沖突)
Duplicate entry ‘重復(fù)的用戶名’ for key ‘sys_user.idx_username’
解決方案
方案一 :直接刪除
在刪除用戶數(shù)據(jù)的時(shí)候不使用邏輯刪除,而是直接刪除用戶數(shù)據(jù)
結(jié)果:直接刪除數(shù)據(jù),不符合假刪除邏輯,不推薦
方案二:設(shè)置聯(lián)合唯一索引
字段的唯一約束,改為字段.與刪除標(biāo)記字段的聯(lián)合唯一約束
通過(guò)設(shè)置username和is_deleted聯(lián)合唯一索引
這樣當(dāng)刪除數(shù)據(jù)的時(shí)候,將數(shù)據(jù)的is_deleted字段為1,再次添加相同用戶名的數(shù)據(jù)時(shí),會(huì)判斷是否存在username重復(fù)并且is_deleted = 0(添加數(shù)據(jù)的時(shí)候默認(rèn)為0) 的數(shù)據(jù)(因?yàn)榇藭r(shí)刪除的數(shù)據(jù)is_deleted = 1) 所以可以正常添加數(shù)據(jù)。
那么再次添加用戶名重復(fù)的數(shù)據(jù)(未刪除)的時(shí)候會(huì)再次觸發(fā)唯一索引
Duplicate entry '重復(fù)用戶名-0' for key ‘sys_user.idx_username’
注意:(可以忽略上面的使用username和is_deleted字段做唯一索引的做法)
上面這樣還會(huì)出現(xiàn)一個(gè)問(wèn)題,當(dāng)再次刪除數(shù)據(jù)的時(shí)候(此時(shí)數(shù)據(jù)庫(kù)表中已經(jīng)有刪除的遺留數(shù)據(jù)),username和is_deleted聯(lián)合唯一索引還是會(huì)重復(fù),如圖表示:
問(wèn)題解決方案:
參考鏈接:邏輯刪除和唯一約束沖突的解決方案
此時(shí)可以追加一個(gè)刪除記錄字段,默認(rèn)為1
此時(shí)聯(lián)合唯一索引為:
第一次添加數(shù)據(jù)的時(shí)候,deleteAt默認(rèn)為1
第二次添加相同用戶名數(shù)據(jù)會(huì)觸發(fā)唯一索引(username相同 并且deleteAt=1)
第一次刪除數(shù)據(jù)的時(shí)候,給deleteAt字段設(shè)置當(dāng)前時(shí)間戳,然后再刪除數(shù)據(jù)
第三次添加和刪除用戶相同用戶名的數(shù)據(jù)時(shí),可以正常添加
第二次刪除數(shù)據(jù)的時(shí)候因?yàn)闀r(shí)間戳設(shè)置的不同,可以正常刪除
到此這篇關(guān)于mybatis-plus邏輯刪除與唯一約束沖突問(wèn)題的文章就介紹到這了,更多相關(guān)mybatis-plus邏輯刪除與唯一約束沖突內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot3利用AOP實(shí)現(xiàn)IP黑名單功能
在Web應(yīng)用開發(fā)中,控制對(duì)特定IP地址的訪問(wèn)權(quán)限是一個(gè)常見(jiàn)的需求,通過(guò)實(shí)現(xiàn)IP黑白名單功能,我們可以允許某些IP地址訪問(wèn)應(yīng)用,同時(shí)拒絕其他IP地址的訪問(wèn),本文將詳細(xì)介紹SpringBoot3利用AOP實(shí)現(xiàn)IP黑名單功能,并附上相應(yīng)的代碼片段,需要的朋友可以參考下2024-09-09SpringBoot使用Maven實(shí)現(xiàn)多環(huán)境配置管理
軟件開發(fā)中經(jīng)常有開發(fā)環(huán)境、測(cè)試環(huán)境、生產(chǎn)環(huán)境,而且一般這些環(huán)境配置會(huì)各不相同,本文主要介紹了SpringBoot使用Maven實(shí)現(xiàn)多環(huán)境配置管理,感興趣的可以了解一下2024-01-01Swagger實(shí)現(xiàn)動(dòng)態(tài)條件注入與全局?jǐn)r截功能詳細(xì)流程
這篇文章主要介紹了Swagger實(shí)現(xiàn)動(dòng)態(tài)條件注入與全局?jǐn)r截功能詳細(xì)流程,Swagger 可以提供 API 操作的測(cè)試文檔,本文記錄 Swagger 使用過(guò)程中遇到的小問(wèn)題2023-01-01JPA之EntityManager踩坑及解決:更改PersistenceContext
這篇文章主要介紹了JPA之EntityManager踩坑及解決:更改PersistenceContext方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02