当软删除遇上联合主键

数据大多是软删除的,而有时候遇到联合主键就头疼了,例如

public class Thumbup
{
public int Id {get;set;}
public int UserId {get;set;}
public int BlogId {get;set;}
public bool IsDeleted {get;set;}
}

在这个点赞表中,每人只能赞一次,因此通过联合主键(UserId, BlogId) 实现唯一约束。 但是当软删除之后,再赞一次的时候,就无法插入数据了,因为违反了唯一性约束。解决这个问题,第一想法就是把 IsDeleted 改成

public DateTimeOffSet DaletedAt {get;set;}

再修改联合主键包含 DaletedAt,这样就避免了软删除之后,无法插入新数据了。但是这样的话,索引也变得更复杂了,应该会导致操作数据的效率降低,那么是不是还有更好的解决办法呢?外事不决问 Google,果然这个问题早就有很多人遇到了,有人把 IsDeleted 字段改成 public Guid DeletedToken {get;set;} 利用不重复的 Guid 来实现,也是一个思路,但是问题依旧。

还有一个更好的解决办法,不过需要数据库支持,那就是有条件的唯一索引,意思就是给索引加一个条件,伪代码:Create Index on (UserId & BlogId) where IsDeleted == false 

目前用的 mongodb 有 partial index ,其他数据库等遇到再更新。

posted @   蝌蝌  阅读(1213)  评论(1编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
点击右上角即可分享
微信分享提示