• 当软删除遇上联合主键


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

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

  • 相关阅读:
    Docker的使用
    Django常见问题
    Linux系统使用
    Nginx
    Redis
    MySQL基础、主从复制、优化
    Python常见的问题
    Python基础知识
    Vue的使用
    python监控tomcat日记文件
  • 原文地址:https://www.cnblogs.com/kexxxfeng/p/8988871.html
Copyright © 2020-2023  润新知