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

Stella981
• 阅读 944

背景

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

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
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:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Karen110 Karen110
3年前
一篇文章带你了解JavaScript日期
日期对象允许您使用日期(年、月、日、小时、分钟、秒和毫秒)。一、JavaScript的日期格式一个JavaScript日期可以写为一个字符串:ThuFeb02201909:59:51GMT0800(中国标准时间)或者是一个数字:1486000791164写数字的日期,指定的毫秒数自1970年1月1日00:00:00到现在。1\.显示日期使用
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
2个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
皕杰报表(关于日期时间时分秒显示不出来)
在使用皕杰报表设计器时,数据据里面是日期型,但当你web预览时候,发现有日期时间类型的数据时分秒显示不出来,只有年月日能显示出来,时分秒显示为0:00:00。1.可以使用tochar解决,数据集用selecttochar(flowdate,"yyyyMMddHH:mm:ss")fromtablename2.也可以把数据库日期类型date改成timestamp
Wesley13 Wesley13
2年前
Java日期时间API系列31
  时间戳是指格林威治时间1970年01月01日00时00分00秒起至现在的总毫秒数,是所有时间的基础,其他时间可以通过时间戳转换得到。Java中本来已经有相关获取时间戳的方法,Java8后增加新的类Instant等专用于处理时间戳问题。 1获取时间戳的方法和性能对比1.1获取时间戳方法Java8以前
Stella981 Stella981
2年前
Django之Django模板
1、问:html页面从数据库中读出DateTimeField字段时,显示的时间格式和数据库中存放的格式不一致,比如数据库字段内容为2012082616:00:00,但是页面显示的却是Aug.26,2012,4p.m.答:为了页面和数据库中显示一致,需要在页面格式化时间,需要添加<td{{dayrecord.p\_time|date:
Stella981 Stella981
2年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Stella981 Stella981
2年前
HIVE 时间操作函数
日期函数UNIX时间戳转日期函数: from\_unixtime语法:   from\_unixtime(bigint unixtime\, string format\)返回值: string说明: 转化UNIX时间戳(从19700101 00:00:00 UTC到指定时间的秒数)到当前时区的时间格式举例:hive   selec
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable