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
:表示存在的值
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Sa-Token不同模式实现单地登录 多地登录 同端互斥登录
这篇文章主要为大家介绍了Sa-Token不同模式实现单地登录 多地登录 同端互斥登录,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-07-07SpringBoot使用thymeleaf实现一个前端表格方法详解
Thymeleaf是一个现代的服务器端 Java 模板引擎,适用于 Web 和独立环境。Thymeleaf 的主要目标是为您的开发工作流程带来优雅的自然模板,本文就来用它实现一个前端表格,感兴趣的可以了解一下2022-10-10MyEclipse如何将项目的开发环境与服务器的JDK 版本保持一致
我们使用MyEclipse开发Java项目开发中,偶尔会遇到因项目开发环境不协调,导致这样那样的问题,在这里以把所有环境调整为JDK1.6 为例,给大家详细介绍MyEclipse如何将项目的开发环境与服务器的JDK 版本保持一致,需要的朋友参考下吧2024-04-04解决nacos启动报错Server check fail, please che
这篇文章主要介绍了nacos启动 Server check fail, please check server localhost ,port 9848 is available的错误原因以及解决方法,需要的朋友可以参考下2023-09-09
最新评论