数据大多是软删除的,而有时候遇到联合主键就头疼了,例如
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 ,其他数据库等遇到再更新。