MyBatisPlus 公共字段自动填充(常用于更新创建/更新时间)

1.方法一 (可以更新任何字段)

注意:MyMetaObjectHandler.java中更新的字段对应的实体类属性必须使用@TableField(value = "create_date", fill = FieldFill.INSERT) 注解, fill = FieldFill.INSERT代表insert操作时自动填充值

import com.项目用户实体.SysUser;
import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import org.apache.commons.lang3.StringUtils;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;

import javax.servlet.http.HttpServletRequest;
import java.time.LocalDateTime;
import java.util.Objects;

/**
 * insert + update 自动填充公共值
 */
@Configuration //使用@Component无效
public class MyMetaObjectHandler implements MetaObjectHandler {
    @Override
    public void insertFill(MetaObject metaObject) {
        //fillStrategy填充策略,默认有值不覆盖,如果提供的值为null也不填充
        this.fillStrategy(metaObject, "createDate", LocalDateTime.now());
        this.fillStrategy(metaObject, "createBy", getUserName());
    }

    @Override
    public void updateFill(MetaObject metaObject) {
        this.fillStrategy(metaObject, "updateBy", getUserName());
    }

    //获取当前用户信息
    public String getUserName(){
        //获取到当前线程绑定的请求对象
        HttpServletRequest request = ((ServletRequestAttributes) Objects.requireNonNull(RequestContextHolder.getRequestAttributes())).getRequest();
        //已经拿到session,就可以拿到session中保存的用户信息了。
        SysUser user = (SysUser) request.getSession().getAttribute("user");

        if(null == user || StringUtils.isBlank(user.getUserName())){
            return "admin";
        }
        return user.getUserName();
    }
}

1.方法二 (只能在update时才能自动更新值)

以下CommonEntity .java是我项目中实体都会继承的基类,

其中@TableField(value = "update_date", fill = FieldFill.UPDATE, update = "now()") // 当执行更新操作时update_date字段会自动设置值为now()

但也只是update操作时会自动填充,其他操作则无效,其他操作只能使用方法一

import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.annotation.TableField;
import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.Data;
import org.springframework.format.annotation.DateTimeFormat;

import java.time.LocalDateTime;

@Data
public class CommonEntity {

    @TableField(value = "create_by", fill = FieldFill.INSERT) //insert无值时配合MyMetaObjectHandler类自动生成
    private String createBy;

    @TableField(value = "create_date", fill = FieldFill.INSERT) //新增时MyMetaObjectHandler类自动设置值
    @DateTimeFormat(pattern = "yyyy-MM-dd")//解决前端String日期传到前台Date日期报错的问题,date传到前台展示时自动转成String
    @JsonFormat(pattern="yyyy/MM/dd", timezone="GMT+12")   //解决日期传到前台少 一天的问题
    private LocalDateTime createDate;  //已开启自动驼峰, 所以不能写成createDate, 否则自动生成的sql就会去找create_Date

    @TableField(value = "update_by", fill = FieldFill.UPDATE) //UPDATE无值时配合MyMetaObjectHandler类自动生成
    private String updateBy;

    @DateTimeFormat(pattern = "yyyy-MM-dd")//解决前端String日期传到前台Date日期报错的问题,date传到前台展示时自动转成String
    @JsonFormat(pattern="yyyy/MM/dd", timezone="GMT+12")   //解决日期传到前台少 一天的问题
    @TableField(value = "update_date", fill = FieldFill.UPDATE, update = "now()") // 更新时自动设置值为now()
    private LocalDateTime  updateDate;

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

往事不堪回首..

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值