mybatisPlus实现逻辑删除,自动生成创建时间和更新时间方式

 更新时间:2024年09月22日 10:40:20   作者:Ys20  
MyBatisPlus框架中,通过@TableField(fill=FieldFill.INSERT)和@TableField(fill=FieldFill.UPDATE)注解可以实现在插入和更新时自动填充字段,比如创建时间和更新时间,使用@TableLogic注解标识逻辑删除字段

mybatisPlus逻辑删除,自动生成创建时间和更新时间

下面是一个抽象类,由于这3个属性每个表都要用到,所以用一个抽象类写好属性,被实体类继承

@TableField(fill = FieldFill.INSERT)中fill表示填充字段的方式。

FieldFill枚举类中有三个值

  • FieldFill.DEFAULT:默认不做任何填充;
  • FieldFill.INSERT:插入时填充字段;
  • FieldFill.UPDATE:更新时填充字段。

在这里我只用到了插入和更新

@TableLogic是用于标识逻辑删除的字段。

在删除时,不会真正删除数据库表中的数据,而是将其标记为已删除状态。

package com.abc.booksys.domain;

import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableLogic;
import com.baomidou.mybatisplus.annotation.Version;

import java.util.Date;

public abstract class ValueObject {

    //   图书创建时间  (执行MP的自动FILL操作,当增加记录的时候)
    @TableField(fill = FieldFill.INSERT)
    private Date createTime;
    //   图书修改时间
    @TableField(fill=FieldFill.INSERT_UPDATE)
    private Date updateTime;

    @TableLogic
    private int isDeleted;
}

MyMetaObjectHandler.java

package com.abc.booksys.utils;

import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import lombok.extern.slf4j.Slf4j;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;

import java.util.Date;

@Slf4j
@Component   //自定义一个MetaObjectHandler的实现类,注入到容器中,就会被MP自动识别,并使用
public class MyMetaObjectHandler implements MetaObjectHandler {

    @Override
    public void insertFill(MetaObject metaObject) {
        log.info("start insert fill ....");
        metaObject.setValue("createTime", new Date());
        metaObject.setValue("updateTime", new Date());
    }

    @Override
    public void updateFill(MetaObject metaObject) {
        log.info("start update fill ....");
        metaObject.setValue("updateTime", new Date());
    }

}

实体类

package com.abc.booksys.domain;


import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
import lombok.NoArgsConstructor;
import com.abc.booksys.domain.ValueObject;
@Data
@NoArgsConstructor
@TableName("tbl_book")
public class Book extends ValueObject{
    @TableId("isbn")
    private String isbn;
    private String name;
    private double price;
}

yml文件

#mybatis-plus配置
mybatis-plus: 
    #逻辑删除
  global-config:
    db-config:
      logic-delete-field: is_deleted
      logic-delete-value: 1
      logic-not-delete-value: 0

其中:

logic-delete-field用于绑定逻辑删除的数据库中的字段属性

  • logic-delete-value:表示已删除的值
  • logic-not-delete-value:表示存在的值

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Mybatis游标查询大量数据方式

    Mybatis游标查询大量数据方式

    这篇文章主要介绍了Mybatis游标查询大量数据方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-02-02
  • JAVA中对List进行查询

    JAVA中对List进行查询

    下面小编就为大家带来一篇在java List中进行模糊查询的实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2021-08-08
  • mybatis-plus如何使用mapper的xml

    mybatis-plus如何使用mapper的xml

    这篇文章主要介绍了mybatis-plus如何使用mapper的xml问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06
  • Sa-Token不同模式实现单地登录 多地登录 同端互斥登录

    Sa-Token不同模式实现单地登录 多地登录 同端互斥登录

    这篇文章主要为大家介绍了Sa-Token不同模式实现单地登录 多地登录 同端互斥登录,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-07-07
  • MyBatis-Plus中SimpleQuery查询实现

    MyBatis-Plus中SimpleQuery查询实现

    本文主要介绍了MyBatis-Plus中SimpleQuery查询实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08
  • SpringBoot使用thymeleaf实现一个前端表格方法详解

    SpringBoot使用thymeleaf实现一个前端表格方法详解

    Thymeleaf是一个现代的服务器端 Java 模板引擎,适用于 Web 和独立环境。Thymeleaf 的主要目标是为您的开发工作流程带来优雅的自然模板,本文就来用它实现一个前端表格,感兴趣的可以了解一下
    2022-10-10
  • SpringMVC访问静态资源的三种方式小结

    SpringMVC访问静态资源的三种方式小结

    这篇文章主要介绍了SpringMVC访问静态资源的三种方式小结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-02-02
  • MyEclipse如何将项目的开发环境与服务器的JDK 版本保持一致

    MyEclipse如何将项目的开发环境与服务器的JDK 版本保持一致

    我们使用MyEclipse开发Java项目开发中,偶尔会遇到因项目开发环境不协调,导致这样那样的问题,在这里以把所有环境调整为JDK1.6 为例,给大家详细介绍MyEclipse如何将项目的开发环境与服务器的JDK 版本保持一致,需要的朋友参考下吧
    2024-04-04
  • 下一代Eclipse 步入云端

    下一代Eclipse 步入云端

    代号Che的下一代Eclipse IDE将运行在云端,可以在任何机器上打开浏览器写代码。项目的建立、编辑、debug、部署可以都在一个仓库中进行,需要的朋友可以参考下
    2015-12-12
  • 解决nacos启动报错Server check fail, please check server localhost ,port 9848 is available的问题

    解决nacos启动报错Server check fail, please che

    这篇文章主要介绍了nacos启动 Server check fail, please check server localhost ,port 9848 is available的错误原因以及解决方法,需要的朋友可以参考下
    2023-09-09

最新评论