mybatis-plus 自动填充的时间跟真实时间不一致解决方案

下午在实现一个简单的逻辑删除的时候发现,数据库中的创建时间,更新时间等都与目前时间不一致,于是网上翻了翻资料才发现需要设置数据库的时区,以此博文巩固一下。

问题出现:

在实现删除标签功能的时候,为了节省步骤,采取mp的自动填充策略:

  • 用注解标识需要填充的字段,如:@TableField( fill = FieldFill.INSERT )
  • 配置实现类

标签类如下,需要填充字段也配置好了。

package com.fox.domain.entity;

import java.util.Date;

import java.io.Serializable;

import com.baomidou.mybatisplus.annotation.*;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

/**
 * 标签(Tag)表实体类
 *
 * @author makejava
 * @since 2024-01-28 20:05:51
 */
@SuppressWarnings("serial")
@Data
@AllArgsConstructor
@NoArgsConstructor
@TableName("sg_tag")
public class Tag  {
    @TableId
    private Long id;

    //标签名
    private String name;

    @TableField(fill = FieldFill.INSERT)
    private Long createBy;

    @TableField(fill = FieldFill.INSERT)
    private Date createTime;
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private Long updateBy;
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private Date updateTime;
    //删除标志(0代表未删除,1代表已删除)、
    //逻辑删除
    @TableLogic
    private Integer delFlag;
    //备注
    private String remark;

}

配置类如下:

package com.fox.handler.mybatisplus;

import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import com.fox.utils.SecurityUtils;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;

import java.util.Date;

@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
    @Override
    public void insertFill(MetaObject metaObject) {
        Long userId = null;
        try {
            userId = SecurityUtils.getUserId();
        } catch (Exception e) {
            e.printStackTrace();
            userId = -1L;//表示是自己创建
        }
        this.setFieldValByName("createTime", new Date(), metaObject);
        this.setFieldValByName("createBy",userId , metaObject);
        this.setFieldValByName("updateTime", new Date(), metaObject);
        this.setFieldValByName("updateBy", userId, metaObject);
    }

    @Override
    public void updateFill(MetaObject metaObject) {
        this.setFieldValByName("updateTime", new Date(), metaObject);
        this.setFieldValByName(" ", SecurityUtils.getUserId(), metaObject);
    }
}

 但是当我们实现删除的时候:

却发现数据库中的字段时间显示不对,与当前时间差了8个小时:

mybatis-plus 自动填充的时间跟真实时间不一致解决方案_第1张图片

解决方案:

在yml或者properties中配置数据库连接时候的时区即可,即timezone改为中国即可:

mybatis-plus 自动填充的时间跟真实时间不一致解决方案_第2张图片

    url: jdbc:mysql://localhost:3306/blog?characterEncoding=utf-8&serverTimezone=Asia/Shanghai

 

你可能感兴趣的:(mybatis,oracle,数据库)