如何解決邏輯刪除與資料庫唯一約束衝突
前言
不知道大家有沒有遇到這麼一種業務場景,在業務中有個唯一約束A,當該業務進行邏輯刪除後(設定標記為刪除狀態),再往唯一約束列插入相同的值時,此時會報Duplicate entry,但在業務上,該值時必須要插入的。今天我們就來聊聊處理這種業務場景的幾種思路
解決思路
方案一:不採用邏輯刪除,直接物理刪除
方案二:新建歷史表
主表進行物理刪除,同時將刪除的記錄儲存到歷史表中
方案三:取消表的唯一約束,同時引入redis來保證唯一約束
取消表的唯一約束,在專案中引入redis,通過redis來判重,新增時往redis set記錄,刪除時,刪除redis記錄
方案四:變更刪除標記為時間戳
將刪除狀態不以0,1表示,而是以時間戳為值,然後將刪除狀態為與之前的唯一約束A重新組成唯一聯合約束index(A、del_flag),刪除時變更del_flag的時間戳
方案五:保留刪除標記,同時新建一個欄位del_unique_key
保留刪除狀態位,再新增一個欄位del_unique_key,該欄位預設值為0,欄位型別和大小與主鍵id保持一致,同時與原先的唯一約束重新組成聯合唯一約束index(A,del_unique_key),業務進行邏輯刪除,變更del_unique_key的值為該刪除行的主鍵id
方案的取捨
方案一得從業務的角度上考慮了,如果物理刪除,對業務無損,那就無所謂了。方案二等於需要刪除的記錄的表都需要有歷史表,如果僅僅是用來實現記錄刪除記錄,感覺有點大材小用。方案三引入redis,雖然也可以解決問題,但是又額外增加複雜度,同時還得保證redis和資料庫的一致性。方案四和方案五其實實現的思路是一樣,不過如果已經是線上上跑的業務,還是推薦用第五種方案,畢竟新增欄位正常對已有的業務影響相對較小,如果是第四種方案,直接將標誌位修改為時間戳,可能還會涉及改業務。如果是新增業務,第四種和第五種方案比較推薦
相關文章
- MyBatisPlus解決邏輯刪除與唯一索引的相容問題MyBatis索引
- 【PK】Oracle 10g刪除主鍵約束後無法刪除唯一約束索引問題的模擬與分析Oracle 10g索引
- 解決資料庫的索引亂碼問題,先刪除外來鍵約束,再刪除主鍵約束及其索引資料庫索引
- [求助][資料庫]表間約束的刪除完整性?資料庫
- (10)邏輯綜合新增約束(環境約束)
- 資料庫,邏輯刪還是物理刪?資料庫
- Mysql-基本練習(06-唯一約束、外來鍵約束、新增、刪除單列)MySql
- 如解決jquery與原生js衝突的問題jQueryJS
- SQL Server實戰三:資料庫表完整性約束及索引、檢視的建立、編輯與刪除SQLServer資料庫索引
- 新增/刪除約束(Oracle)Oracle
- 如何解決 touchstart 事件與 click 事件的衝突事件
- 資料庫常用約束資料庫
- mysql資料庫約束MySql資料庫
- 如何解決git程式碼衝突Git
- mysql中外來鍵約束級聯更新與刪除MySql
- 資料庫約束 主鍵-唯一性-Check-外來鍵資料庫
- (9)邏輯綜合新增約束(時序、DRC)
- MybatisPlus - [05] 邏輯刪除MyBatis
- 資料完整性約束:主鍵、外來鍵、各種約束的建立刪除語句
- [MYSQL] 資料庫建立與刪除MySql資料庫
- Sqlserver中所有約束的型別,建立、修改與刪除SQLServer型別
- Oracle主鍵約束、唯一鍵約束、唯一索引的區別(轉)Oracle索引
- MongoDB資料庫中更新與刪除資料MongoDB資料庫
- 邏輯dg刪除主庫過期歸檔日誌
- PostgreSQL唯一約束如何使用?SQL
- PostgreSQL:資料庫的建立與刪除SQL資料庫
- 批量刪除MSSQL 中主外來鍵約束SQL
- mysql 刪除老是報外來鍵約束MySql
- 資料庫補丁衝突解決方案 (文件 ID 1674432.1)資料庫
- 什麼是 IP 衝突以及如何解決?
- 邏輯資料庫的管理資料庫
- 【mybatis-plus】分頁、邏輯刪除MyBatis
- 解決無法刪除表,提示被外來鍵約束引用
- IP衝突 資料庫時斷時續資料庫
- 【INDEX】Oracle中主鍵、唯一約束與唯一索引之區別IndexOracle索引
- 資料庫 - 索引、基本表建立與刪除資料庫索引
- 資料庫(表)的邏輯備份與恢復資料庫
- SQL Server唯一約束的使用SQLServer