当前位置: 首页 > article >正文

如何解决‘逻辑删除‘和‘唯一索引‘冲突的问题

场景

当要对保证某些可编辑字段的唯一性时,代码需要在插入和更新时都进行唯一性校验,这很繁琐。

因此想到采用将对于唯一性的校验直接交给数据库进行,通过数据库唯一索引实现。

但这就又出现了另一个问题:由于采用的是“逻辑删除”,那么会造成唯一字段值相同的数据只能删除一次的情况。第二次删除时,由于已存在 del_flag 值为 1 的数据,会报错“违反唯一约束”

解决方案

基于mysql“唯一约束对 Null 失效”的原理,将被删数据的逻辑删除字段置为 null 即可。如果使用的是 mybatis-plus,可以直接通过@TableLogic注解实现

    /**
     * 是否删除
     *
     * <p>
     *     为解决'逻辑删除'和'唯一索引'冲突问题,而将逻辑删除字段设置为NULL
     * </p>
     */
    @TableLogic(value = "0", delval = "NULL")
    private Boolean deleteFlag;

这样就可以在数据库层面轻松实现唯一性的保证,且'逻辑删除'和'唯一索引'不会冲突。

此时当入参违反唯一性约束时就会抛出异常,我们需要对异常进行处理,以向前端返回更加友好的报错信息。

try {
    thisGiftProductService.saveThisGiftProduct(thisGiftProductDO, request);
    return RestResult.<Void>builder().success("保存成功");
} catch (Exception e) {
    log.error("新增错误", e);
    Throwable cause = e.getCause();
    if (cause instanceof java.sql.SQLIntegrityConstraintViolationException) {
        return RestResult.<Void>builder().fail("本品产品编码和组织信息组合不能重复");
    }
    return RestResult.<Void>builder().fail(e.getMessage());
}

核心在于:

log.error("新增错误", e);
Throwable cause = e.getCause();
if (cause instanceof java.sql.SQLIntegrityConstraintViolationException) {
    return RestResult.<Void>builder().fail("本品产品编码和组织信息组合不能重复");
}

之所以采用这种方法,是因为 java.sql.SQLIntegrityConstraintViolationException 异常是无法作为 catch 参数捕捉的。


http://www.kler.cn/a/427856.html

相关文章:

  • 我的创作纪念日——成为创作者的 第365天(1年)
  • Golang :用Redis构建高效灵活的应用程序
  • 基于互联网+智慧水务信息化整体解决方案
  • 在Ubuntu子系统中基于Nginx部署Typecho
  • 代码随想录34 动态规划
  • 【gRPC-gateway】初探grpc网关,插件安装,默认实现,go案例
  • 七、CNN的变体(更新中)
  • 51c嵌入式~单片机合集3
  • 【jvm】垃圾回收的优点和原理
  • Docker Compose 和 Kubernetes 之间的区别?
  • oracle之用户的相关操作
  • 【C#】键值对的一种常见数据结构Dictionary<TKey, TValue>
  • NAS-FCOS论文总结
  • 【xLSTM-Transformer序列分类】Pytorch使用xLSTM-Transformer对序列进行分类源代码
  • 【Redis集群】使用docker compose创建docker集群,并暴露外部接口
  • Android APP自学笔记
  • 一、web基础和http协议
  • Apache Doris Sql Cache
  • draggable插件——实现元素的拖动排序——拖动和不可拖动的两种情况处理
  • 第一节、电路连接【51单片机-TB6600驱动器-步进电机教程】
  • Java课程设计项目-servlet+jsp美食系统、菜品管理系统
  • 数据结构代码归纳
  • THENA大涨将对整个DeFi市场产生怎样的影响?
  • QT 左右 上下,拉伸 分配窗口大小
  • [Python | CS基础 ]Python多线程`threading`和多进程`multiprocessing`
  • 相机动态/在线标定