问题描述
通过MyBatis-Plus使用@TableField注释设置自动填充时间LocalDateTime类型没有效果
解决方案
- 添加 mybatis plus 的依赖
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.4.2</version>
</dependency>
- 在需要填充的实体类字段上添加注解
/**
* 创建时间
*/
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
@TableField(value = "create_time", fill = FieldFill.INSERT)
private LocalDateTime createTime;
/**
* 创建人
*/
@TableField(value = "create_user")
private String createUser;
/**
* 更新时间
*/
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
@TableField(value = "update_time", fill = FieldFill.UPDATE)
private LocalDateTime updateTime;
/**
* 更新人
*/
@TableField(value = "update_user", fill = FieldFill.UPDATE)
private String updateUser;
加入 @DateTimeFormat 注解是为了格式化参数,防止参数接收不到,并且可以对日期的格式进行转化
加入 @JsonFormat 注解是为了进行出参格式化转换为想要的格式
- 在项目的config包下新建自动填充处理类使其实现接口 MetaObjectHandler ,并重写其方法
import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import lombok.extern.slf4j.Slf4j;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.context.annotation.Primary;
import org.springframework.stereotype.Component;
import java.time.LocalDateTime;
/**
* @author Guan
* @date 2021/8/27
*/
@Slf4j
@Primary
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
/**
* 插入元对象字段填充(用于插入时对公共字段的填充)
*
* @param metaObject 元对象
*/
@Override
public void insertFill(MetaObject metaObject) {
log.info("start insert fill....");
this.setFieldValByName("createTime", LocalDateTime.now(), metaObject);
this.setFieldValByName("updateTime", LocalDateTime.now(), metaObject);
this.setFieldValByName("updateUser", "", metaObject);
}
/**
* 更新元对象字段填充(用于更新时对公共字段的填充)
*
* @param metaObject 元对象
*/
@Override
public void updateFill(MetaObject metaObject) {
log.info("start update fill....");
this.setFieldValByName("updateTime", LocalDateTime.now(), metaObject);
this.setFieldValByName("updateUser", "", metaObject);
}
}
实现类中的方法参数第一个为 实体类需要自动填充所对应的字段,第二个为需要自动填充的值
注意:
@Primary 注解是为了解决bean冲突所使用的,如果没有bean冲突可以不加。下面会继续说到
至此,进行测试问题基本已经解决问题了,接下来说一些其它的问题。
其它问题一
通过观察上述代码可以发现,我的实体类中创建人属性没有选择自动注入,本人选择的方法是在 Service层的实现类中通过使用以下方法获取当前登录用户信息,进行设置创建人属性。
String account = LoginContextHolder.getContext().getUser().getAccount();
param.setCreateUser(account);
param 为实体类参数
其它问题二
如果通过自己自定义自动填充处理类使其实现接口 MetaObjectHandler 方法后,发现有 bean 报错冲突提示,此时就需要使用 @Primary 注解来解决,@Primary 注解的作用为在其中一个bean加上该注解后,则把该bean选择为默认使用。
此外网上还有其它方法,列举如下(本人选择了直接用 @Primary 注解来解决),以供参考:
- 在注入的属性添加 @Qualifier 指定 beanName ,以明确使用哪一个 bean
- SpringBoot项目中直接在Mapper接口上添加 @Mapper ,不使用@MapperScan ,若需要使用 @MapperScan 注解,则需要配置好扫描的范围,避免重复扫描注入 spring bean 导致出现问题。
参考资料:
CSDN-aim:https://blog.csdn.net/weixin_44866272/article/details/116696444
博客园-private_yang:实体类的date类型和数据库的datetime类型不匹配问题
CSDN-疯狂码字中:Springboot项目启动异常
CSDN-月下泛舟:@DateTimeFormat 和 @JsonFormat 注解