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接口,并实现其中的 insertFill 和 updateFill 方法,如下:
@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);
}
}