MybatisPlus改造逻辑删除有多方便

MybatisPlus的逻辑删除可以有效保留历史数据。之前没有用逻辑删除的项目,想改造成逻辑删除总共需要几步?

答案:4步搞定

一、修改pom.xml的MybatisPlus版本(注意版本兼容性)

    
        ...
        
        3.3.0
    

二、application.yml中添加逻辑删除配置

mybatis-plus:
  global-config:
    db-config:
      logic-delete-field: flag # 全局逻辑删除的实体字段名(since 3.3.0,配置后可以忽略不配置步骤2) 建议字段使用deleted
      logic-delete-value: 1 # 逻辑已删除值(默认为 1) 默认可以不配
      logic-not-delete-value: 0 # 逻辑未删除值(默认为 0) 默认可以不配

三、在java实体类中增加标志位属性(private boolean deleted;)

package cc.mrbird.febs.cos.entity;

import java.time.LocalDateTime;
import java.io.Serializable;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableLogic;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.experimental.Accessors;

/**
 * 耗材类型
 *
 * @author FanK
 */
@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
public class ConsumableType implements Serializable {

    private static final long serialVersionUID = 1L;

    @TableId(value = "ID", type = IdType.AUTO)
    private Integer id;
    /**
     * 耗材类别名称
     */
    private String name;

    /**
     * 备注
     */
    private String content;

    /**
     * 创建时间
     */
    private String createDate;

    /**
     * 逻辑删除标志位
     */
    //@TableLogic 3.3.0 版本后 可以不配@TableLogic标签
    private boolean deleted;

}

四、在数据库表中增加标志位字段deleted(类型bit)

MybatisPlus改造逻辑删除有多方便_第1张图片

然后重启springboot,逻辑删除即生效

修改前

MybatisPlus改造逻辑删除有多方便_第2张图片

修改后:

MybatisPlus改造逻辑删除有多方便_第3张图片MybatisPlus改造逻辑删除有多方便_第4张图片

需要注意的是,如果这个表涉及到通过mapper.xml编写的复杂查询,需要手动修改相关mapper.xml中的sql语句,否则其他业务逻辑会出现异常。

比如:

MybatisPlus改造逻辑删除有多方便_第5张图片

页面第一条数据在数据库中已经逻辑删除了,但是仍显示在界面上。

MybatisPlus改造逻辑删除有多方便_第6张图片

 需要在StockPutMapper.xml中添加查询条件:

and sp.deleted = 0

MybatisPlus改造逻辑删除有多方便_第7张图片





    
    

如果不想将全部表改造逻辑删除,只改造部分表为逻辑删除,剩余改造的表增删改查操作受影响吗?

答案:不受影响,只要java实体类没有设置删除标志属性,mybatisplus自动生成的表操作仍按原始操作进行。比如将本例中的ConsumableType实体类,添加private boolean deleted;属性后,删除sql变为update ... set ... where ...,这时将private boolean deleted;属性注释掉,删除操作恢复为原来的 delete ... from ...。

15.扩展功能-逻辑删除_哔哩哔哩_bilibili

逻辑删除 | MyBatis-Plus

你可能感兴趣的:(spring,java,后端)