前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mybatis Plus 更新时间 creatDate字段报错 Could not set property 'creatDate' 原

Mybatis Plus 更新时间 creatDate字段报错 Could not set property 'creatDate' 原

作者头像
故久
发布2020-07-03 11:25:20
4.5K0
发布2020-07-03 11:25:20
举报
文章被收录于专栏:故久

背景

MySQL数据库,表中字段名为creatDate,类型为datetime。Java实体类中对应的变量是 java.time.LocalDateTime类型的creatDate

当使用新增和更新的方法时,创建日期时间和最后更新时间自动更新。

实体类

代码语言:javascript
复制
/**
 * 创建日期
 */
@JsonFormat(pattern="yyyy-MM-dd HH:mm:ss")
@TableField(value = "creatDate",fill = FieldFill.INSERT)
private LocalDateTime creatDate;

/**
 * 更新日期
 */
@JsonFormat(pattern="yyyy-MM-dd HH:mm:ss")
@TableField(value = "lastUpDate",fill = FieldFill.INSERT_UPDATE)
private LocalDateTime lastUpDate;

采用AOP的思想,实现 MetaObjectHandler接口,并实现其中的 insertFillupdateFill 方法,如下:

代码语言:javascript
复制
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {

    @Override
    public void insertFill(MetaObject metaObject) {
        this.setFieldValByName("creatDate",new Date(), metaObject);
        this.setFieldValByName("lastUpDate", new Date(), metaObject);
    }

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

在进行新增操作时就报Could not set property 'creatDate' of 'class com.siyuan.articles.model.Content' with value 'Fri Jul 03 10:21:44 CST 2020' Cause: java.lang.IllegalArgumentException: argument type mismatch

原因是实体类中是LocalDateTime类型的,而在MyMetaObjectHandler中是new Date()类型的,所以就报这个错了。将MyMetaObjectHandler中的new Date()改为 LocalDateTime.now() 就可以啦;

代码语言:javascript
复制
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {

    @Override
    public void insertFill(MetaObject metaObject) {
        this.setFieldValByName("creatDate",LocalDateTime.now(), metaObject);
        this.setFieldValByName("lastUpDate", LocalDateTime.now(), metaObject);
    }

    @Override
    public void updateFill(MetaObject metaObject) {
        this.setFieldValByName("lastUpDate", LocalDateTime.now(), metaObject);
    }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 背景
相关产品与服务
云数据库 MySQL
腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档