MyBatis-Plus中使用@TableField设置自动填充时间LocalDateTime没有效果解决方案

问题描述

通过MyBatis-Plus使用@TableField注释设置自动填充时间LocalDateTime类型没有效果

解决方案

  1. 添加 mybatis plus 的依赖
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.4.2</version>
</dependency>
  1. 在需要填充的实体类字段上添加注解

	/**
     * 创建时间
     */
    @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 注解是为了进行出参格式化转换为想要的格式

  1. 在项目的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 注解

  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Mybatis-plus 支持自动填充功能,其包括填充时间。 你可以通过在实体类的字段上使用注解 @TableField(fill = FieldFill.INSERT) 来实现自动填充创建时间使用注解 @TableField(fill = FieldFill.UPDATE) 来实现自动填充更新时间。 示例代码: ``` @TableField(fill = FieldFill.INSERT) private LocalDateTime createTime; @TableField(fill = FieldFill.UPDATE) private LocalDateTime updateTime; ``` ### 回答2: Mybatis-Plus是基于Mybatis的增强工具包,该工具包提供了方便快捷的开发方式,其一个重要功能就是自动填充时间自动填充时间功能可以在数据库表创建日期和时间字段时,以特定方式填充或更新这些字段。在Mybatis-Plus自动填充时间可以通过以下几个步骤实现。 第一步,创建实体类 在实体类,需要添加需要自动填充的字段和注解。如下所示: ``` @Data public class User { @TableId(type = IdType.AUTO) private Long id; private String name; private Integer age; @TableField(fill = FieldFill.INSERT) private Date createTime; @TableField(fill = FieldFill.INSERT_UPDATE) private Date updateTime; } ``` 其,@TableField注解fill属性用于指定自动填充的方式,FieldFill.INSERT表示新增时自动填充FieldFill.INSERT_UPDATE表示新增和修改时都自动填充。 第二步,创建处理器 处理器用于在特定条件下填充时间。可以通过实现MetaObjectHandler接口来创建处理器。如下所示: ``` @Component public class MyMetaObjectHandler implements MetaObjectHandler { @Override public void insertFill(MetaObject metaObject) { this.strictInsertFill(metaObject, "createTime", Date.class, new Date()); this.strictInsertFill(metaObject, "updateTime", Date.class, new Date()); } @Override public void updateFill(MetaObject metaObject) { this.strictUpdateFill(metaObject, "updateTime", Date.class, new Date()); } } ``` 其,insertFill方法表示新增时填充,updateFill方法表示更新时填充。通过strictInsertFill和strictUpdateFill方法实现填充。 第三步,配置Mybatis-PlusMybatis-Plus的配置文件,需要添加自动填充的处理器。 ``` @Configuration public class MybatisPlusConfig { @Autowired private MyMetaObjectHandler myMetaObjectHandler; @Bean public MybatisPlusInterceptor mybatisPlusInterceptor() { MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor(); interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL)); return interceptor; } @Bean public GlobalConfig globalConfig() { GlobalConfig config = new GlobalConfig(); config.setMetaObjectHandler(myMetaObjectHandler); return config; } } ``` 其,globalConfig方法用于配置自动填充处理器。在配置,setMetaObjectHandler用于指定处理器。 以上就是Mybatis-Plus自动填充时间的实现过程。通过注解指定需要填充的字段,实现处理器填充,最后在配置文件配置自动填充处理器。自动填充时间功能可以方便地处理数据表时间字段,提高了开发效率。 ### 回答3: Mybatis-PlusMybatis的增强工具,提供了很多方便开发的功能,其包括自动填充时间自动填充时间是指在插入或更新记录时,自动时间字段填充上当前时间。这在开发非常常见,比如我们需要在创建记录时记录下创建时间,或者在更新记录时记录下更新时间Mybatis-Plus提供了两种方式来实现自动填充时间:注解和接口实现。 1.注解方式 使用注解方式需要在实体类添加字段注解使用@DateTimeFormat和@TableField,如下所示: ``` public class User { @TableId(type = IdType.AUTO) private Long id; private String name; @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") @TableField(fill = FieldFill.INSERT) private Date createTime; @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") @TableField(fill = FieldFill.INSERT_UPDATE) private Date updateTime; } ``` 在上述代码,我们为createTime和updateTime字段添加了注解,@TableField的fill属性指定了在插入和更新时自动填充时间。在使用自动填充时,需要在Mybatis-Plus的配置文件开启自动填充功能,配置如下: ``` mybatis-plus: global-config: db-config: logic-delete-value: 1 logic-not-delete-value: 0 id-type: auto field-strategy: not_empty insert-strategy: not_null update-strategy: not_null table-prefix: mp_ logic-delete-field: deleted auto-fill: true ``` 其,auto-fill属性表示是否开启自动填充功能。开启后,在数据插入或更新时,自动将createTime和updateTime字段填充上当前时间。 2. 接口实现方式 除了使用注解方式,我们还可以使用接口实现方式,这种方式更加灵活。需要创建一个自动填充处理器实现MetaObjectHandler接口,如下所示: ``` @Component public class MyMetaObjectHandler implements MetaObjectHandler { @Override public void insertFill(MetaObject metaObject) { this.strictInsertFill(metaObject, "createTime", Date.class, new Date()); } @Override public void updateFill(MetaObject metaObject) { this.strictUpdateFill(metaObject, "updateTime", Date.class, new Date()); } } ``` 在上述代码,我们为createTime和updateTime字段添加了自动填充,通过调用strictInsertFill和strictUpdateFill方法实现。在Mybatis-Plus的配置文件,需要注册这个自动填充处理器,配置如下: ``` mybatis-plus: global-config: db-config: logic-delete-value: 1 logic-not-delete-value: 0 id-type: auto field-strategy: not_empty insert-strategy: not_null update-strategy: not_null table-prefix: mp_ logic-delete-field: deleted meta-object-handler: com.example.mydemo.config.MyMetaObjectHandler ``` 在开启了自动填充功能之后,无论是使用注解方式还是接口实现方式,都可以轻松实现自动填充时间。这可以大大减少开发重复的时间填充操作,提高开发效率。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值