详解MyBatisPlus逻辑删除与唯一索引冲突问题

 更新时间:2021年03月24日 10:12:02   作者:此去经年天问  
这篇文章主要介绍了详解MyBatisPlus逻辑删除与唯一索引冲突问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

1、问题背景:

在开发中,我们经常会有逻辑删除和唯一索引同时使用的情况。但当使用mybatis plus时,如果同时使用逻辑删除和唯一索引,会报数据重复Duplicate entry的问题。

举个例子:

原来数据库结构:

这里location_id是唯一索引

CREATE TABLE `eam_location` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `location_id` varchar(50) UNIQUE NOT NULL COMMENT '位置代码',
  `location_level` tinyint(1) NOT NULL COMMENT '位置级别',
  `location_name` varchar(50) NOT NULL COMMENT '位置名称',
  `parent_location_id` varchar(50) COMMENT '上级位置代码',
  `delete_flag` tinyint(1) DEFAULT 0 COMMENT '软删除',
  `version` int(11) DEFAULT 1 COMMENT '乐观锁',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

这里在删除添加某一条数据后,delete_flag变成0,当删除后delete_flag会变成1,再次添加相同的数据时,由于数据库检测不到原来数据,会报数据重复Duplicate entry的问题

解决办法:参考逻辑删除与唯一约束的需求冲突

SQL数据结构,将delete_flag用时间戳进行表示,唯一索引变成了联合唯一索引 UNIQUE KEY unique_location_delete_flag(location_id, delete_flag) ,当添加一条数据时,delete_flag变成null,当删除数据时,delete_flag变成删除时的一个时间戳。再次添加相同数据时,由于添加的数据是联合唯一索引unique_location_delete_flag ,delete_flag为null,不会产生冲突,多次删除也是,完美解决问题。

CREATE TABLE `eam_location` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `location_id` varchar(50) NOT NULL COMMENT '位置代码',
  `location_level` tinyint(1) NOT NULL COMMENT '位置级别',
  `location_name` varchar(50) NOT NULL COMMENT '位置名称',
  `parent_location_id` varchar(50) COMMENT '上级位置代码',
  `delete_flag` datetime COMMENT '软删除',
  `version` int(11) DEFAULT 1 COMMENT '乐观锁',
  PRIMARY KEY (`id`),
  UNIQUE KEY `unique_location_delete_flag`(`location_id`, `delete_flag`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

entity类:

@AllArgsConstructor
@NoArgsConstructor
@Builder(toBuilder = true)
@Data
@EqualsAndHashCode(callSuper = false)
public class EamEquipmentType implements Serializable {

  private static final long serialVersionUID = 1L;

  /**
   * 数据库自增id
   */
  @TableId(value = "id", type = IdType.AUTO)
  private Integer id;

  /**
   * 设备类型编号
   */
  private String typeId;

  /**
   * 设备类型
   */
  private String typeName;

  /**
   * 设备厂商
   */
  private String manufacture;

  /**
   * 设备型号
   */
  private String model;

  /**
   * 标准设备bom 0:未创建 1:已创建
   */
  private Boolean typeBom;

  /**
   * 标准设备bom id
   */
  private Integer typeBomId;

  /**
   * 创建时间
   */
  private LocalDateTime createTime;

  /**
   * 软删除
   */
  @TableLogic()
  @TableField(fill = FieldFill.INSERT)
  private LocalDateTime deleteFlag;

  /**
   * 乐观锁
   */
  @Version
  @TableField(fill = FieldFill.INSERT)
  private Integer version;

yml配置文件:

mybatis-plus:
 global-config:
  db-config:
   logic-delete-value: "now()" #逻辑删除值是个db获取时间的函数
   logic-not-delete-value: "null" #逻辑未删除值为字符串 "null"

到此这篇关于详解MyBatisPlus逻辑删除与唯一索引冲突问题的文章就介绍到这了,更多相关MyBatisPlus逻辑删除与唯一索引冲突内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 使用feign配置网络ip代理

    使用feign配置网络ip代理

    这篇文章主要介绍了使用feign配置网络ip代理,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06
  • Java实战花店商城系统的实现流程

    Java实战花店商城系统的实现流程

    只学书上的理论是远远不够的,只有在实战中才能获得能力的提升,本篇文章手把手带你用java+Springboot+Maven+mybatis+Vue+Mysql实现一个花店商城系统,大家可以在过程中查缺补漏,提升水平
    2022-01-01
  • springboot调用HTML文件注意事项及说明

    springboot调用HTML文件注意事项及说明

    这篇文章主要介绍了springboot调用HTML文件注意事项及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • Springboot使用MybatisPlus实现mysql乐观锁

    Springboot使用MybatisPlus实现mysql乐观锁

    MySQL中的乐观锁(Optimistic Locking)是一种并发控制策略,本文将使用Springboot和MybatisPlus实现MySQL中的乐观锁,需要的可以参考下
    2024-12-12
  • Java 根据url下载网络资源

    Java 根据url下载网络资源

    这篇文章主要介绍了Java 根据url下载网络资源的示例代码,帮助大家更好的理解和使用Java,感兴趣的朋友可以了解下
    2020-11-11
  • 对Java字符串与整形、浮点类型之间的相互转换方法总结

    对Java字符串与整形、浮点类型之间的相互转换方法总结

    今天小编就为大家分享一篇对Java字符串与整形、浮点类型之间的相互转换方法总结,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-07-07
  • java将一个目录下的所有文件复制n次

    java将一个目录下的所有文件复制n次

    这篇文章主要为大家详细介绍了java将一个目录下的所有文件复制n次,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-08-08
  • JVM 心得 OOM时的堆信息获取方法与分析

    JVM 心得 OOM时的堆信息获取方法与分析

    下面小编就为大家带来一篇JVM 心得 OOM时的堆信息获取方法与分析。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-10-10
  • 若依前后端打成一个JAR包部署的完整步骤

    若依前后端打成一个JAR包部署的完整步骤

    这篇文章主要介绍了如何将若依前后端分离项目打包成jar,不使用nginx转发,前端修改了路由模式和环境变量配置,后端增加了依赖、配置了Thymeleaf和访问路径,需要的朋友可以参考下
    2025-01-01
  • 教你1秒将本地SpringBoot项目jar包部署到Linux环境(超详细!)

    教你1秒将本地SpringBoot项目jar包部署到Linux环境(超详细!)

    spring Boot简化了Spring应用的开发过程,遵循约定优先配置的原则提供了各类开箱即用(out-of-the-box)的框架配置,下面这篇文章主要给大家介绍了关于1秒将本地SpringBoot项目jar包部署到Linux环境的相关资料,超级详细,需要的朋友可以参考下
    2023-04-04

最新评论