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

逻辑删除和唯一约束冲突的解决方案

最近碰到这个问题,需要加一个唯一约束保证数据库数据的唯一性,但突然发现逻辑删除会和唯一约束发生冲突。
查阅相关资料后,也得到了一些解决方案。这里就给出我认为的标准答案吧。

一、问题描述

我这里使用的逻辑删除的字段是isDeletedtinyint类型。
未删除:0,已删除:1。
所以当数据已删除时,状态都是1,这时,已删除的数据里,是允许数据不唯一的。但未删除的数据里数据是要求唯一的。

但如果将isDeleted加入唯一字段约束的话,就会导致已删除的数据也不允许唯一,那就会影响删除业务。于是目前的情况无法使用唯一约束。

二、解决方案

增加一个deleteAt字段,bigint类型。用于记录删除时间的时间戳,未删除时为0。
也就是说,删除数据时维护两个字段,一个isDelete,用来判断是否删除,一个deleteAt,用来记录删除时间。
使用唯一约束时,将deleteAt加入唯一约束。
此时,已删除的数据deleteAt必然不同,所以不会发生重复。
而未删除的数据deleteAt都是0,此时业务字段就受到唯一约束影响,不能发生重复。
完美解决我的问题。

对你有帮助吗?点个赞把~


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

相关文章:

  • 使用three.js 实现vr全景图展示,复制即可用
  • Jenkins管理多版本python环境
  • 树莓派OpenWrt下怎么驱动带USB的摄像头
  • LeetCode - 初级算法 数组(存在重复元素)
  • [TOTP]android kotlin实现 totp身份验证器 类似Google身份验证器
  • 【持续集成与持续部署(CI/CD)工具 - Jenkins】详解
  • springcloud:xxl-job的任务触发机制及调度过期策略
  • IT知识百科:什么是BGP?
  • ubuntu20.04 下载 linux源码和编译简单测试模块
  • Python 变量教程打包和解包参数
  • NHibernate教程_编程入门自学教程_菜鸟教程-免费教程分享
  • Linux系统【centos7】常用系统命令大全
  • 剪枝与重参第二课:修剪方法和稀疏训练
  • webpack5搭建react框架-开发环境配置
  • 【Linux】文件系统
  • C++_07----强制类型转换异常
  • ORACLE EBS 系统主数据管理(2)
  • 《论文阅读》Unified Named Entity Recognition as Word-Word Relation Classification
  • 论文阅读_MAE
  • 快速分析一个行业,这个工具必不可少
  • Nuxt3中的常用seo标签
  • HuggingGPT:一个ChatGPT控制所有AI模型,自动帮人完成AI任务
  • Python 02 数据类型(04元组)
  • CoppeliaSim安装教程(以前叫V-REP)
  • 【李宏毅】深度学习——HW4-Speaker Identification
  • 优思学院|《精益思想》让企业快速应对市场变化的利器