当软删除遇上联合主键

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

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 ,其他数据库等遇到再更新。

你可能感兴趣的:(当软删除遇上联合主键)