下午在实现一个简单的逻辑删除的时候发现,数据库中的创建时间,更新时间等都与目前时间不一致,于是网上翻了翻资料才发现需要设置数据库的时区,以此博文巩固一下。
问题出现:
在实现删除标签功能的时候,为了节省步骤,采取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个小时:
解决方案:
在yml或者properties中配置数据库连接时候的时区即可,即timezone改为中国即可:
url: jdbc:mysql://localhost:3306/blog?characterEncoding=utf-8&serverTimezone=Asia/Shanghai