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

mybatis-plus邏輯刪除與唯一約束沖突問(wèn)題

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

問(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)文章

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

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

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

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

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

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

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

    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-09
  • SpringBoot使用Maven實(shí)現(xiàn)多環(huán)境配置管理

    SpringBoot使用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-01
  • Swagger實(shí)現(xiàn)動(dòng)態(tài)條件注入與全局?jǐn)r截功能詳細(xì)流程

    Swagger實(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-01
  • 詳解Java線程中斷知識(shí)點(diǎn)

    詳解Java線程中斷知識(shí)點(diǎn)

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

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

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

    從面試中的問(wèn)題分析ThreadLocal

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

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

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

最新評(píng)論