zoukankan      html  css  js  c++  java
  • 当软删除遇上联合主键

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

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

  • 相关阅读:
    shell脚本使用记录一:操作文件
    用IDEA在Tomcat上部署项目
    通过反射获取属性名和属性类型
    IDEA设置生成类基本注释信息
    有序的Map集合--LinkedHashMap
    书面格式注意的问题
    悲观锁和乐观锁的区别
    解析xml文件的四种方式
    jsp的四种范围
    jsp的两种跳转方式和区别
  • 原文地址:https://www.cnblogs.com/kexxxfeng/p/8988871.html
Copyright © 2011-2022 走看看