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

Stella981
• 阅读 471

背景

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

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

实体类

_/** _ * 创建日期 */ @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 方法,如下:

@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() 就可以啦;

@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); } }

点赞
收藏
评论区
推荐文章
刚刚好 刚刚好
2个月前
css问题
1、 在IOS中图片不显示(给图片加了圆角或者img没有父级) <div<img src""/</div div {width: 20px; height: 20px; borderradius: 20px; overflow: h
blmius blmius
1年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录 问题 用navicat导入数据时,报错: 原因这是因为当前的MySQL不支持datetime为0的情况。 解决修改sql\mode: sql\mode:SQL Mode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。 全局s
晴空闲云 晴空闲云
2个月前
css中box-sizing解放盒子实际宽高计算
我们知道传统的盒子模型,如果增加内边距padding和边框border,那么会撑大整个盒子,造成盒子的宽度不好计算,在实务中特别不方便。boxsizing可以设置盒模型的方式,可以很好的设置固定宽高的盒模型。 盒子宽高计算假如我们设置如下盒子:宽度和高度均为200px,那么这会这个盒子实际的宽高就都是200px。但是当我们设置这个盒子的边框和内间距的时候,那
Karen110 Karen110
1年前
一篇文章带你了解JavaScript日期
日期对象允许您使用日期(年、月、日、小时、分钟、秒和毫秒)。一、JavaScript的日期格式一个JavaScript日期可以写为一个字符串:Thu Feb 02 2019 09:59:51 GMT+0800 (中国标准时间)或者是一个数字:1486000791164写数字的日期,指定的毫秒数自1970年1月1日00:00:00到现在。 1\. 显示日期使用
艾木酱 艾木酱
1个月前
快速入门|使用MemFire Cloud构建React Native应用程序
> MemFire Cloud是一款提供云数据库,用户可以创建云数据库,并对数据库进行管理,还可以对数据库进行备份操作。它还提供后端即服务,用户可以在1分钟内新建一个应用,使用自动生成的API和SDK,访问云数据库、对象存储、用户认证与授权等功能,可专
Stella981 Stella981
1年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有`time`,和`datetime`两个,本文先说`time`模块。 ### 关于时间戳的几个概念 * 时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。 * 时间元组(`struct_time`),包含9个元素。  `time.struct_time(tm_y
Wesley13 Wesley13
1年前
MySQL查询按照指定规则排序
1.按照指定(单个)字段排序 select * from table_name order id desc; 2.按照指定(多个)字段排序 select * from table_name order id desc,status desc; 3.按照指定字段和规则排序 selec
Wesley13 Wesley13
1年前
PHP中的NOW()函数
是否有一个PHP函数以与MySQL函数`NOW()`相同的格式返回日期和时间? 我知道如何使用`date()`做到这一点,但是我问是否有一个仅用于此的函数。 例如,返回: 2009-12-01 00:00:00 * * * ### #1楼 使用此功能: function getDatetimeNow() {
helloworld_34035044 helloworld_34035044
4个月前
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。 uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid() 或 uuid(sep)参数说明:sep 布尔值,生成的uuid中是否包含分隔符'',缺省为
helloworld_34035044 helloworld_34035044
5个月前
皕杰报表(关于日期时间时分秒显示不出来)
在使用皕杰报表设计器时,数据据里面是日期型,但当你web预览时候,发现有日期时间类型的数据时分秒显示不出来,只有年月日能显示出来,时分秒显示为0:00:00。1.可以使用tochar解决,数据集用select tochar(flowdate,"yyyyMMdd HH:mm:ss") fromtablename2.也可以把数据库日期类型date改成timestamp
helloworld_28799839 helloworld_28799839
2个月前
常用知识整理
# Javascript ## 判断对象是否为空 ```js Object.keys(myObject).length === 0 ``` ## 经常使用的三元运算 > 我们经常遇到处理表格列状态字段如 `status` 的时候可以用到 ``` vue