mybatis时间格式转换异常

一、日期格式转换异常

Java报错Failed to convert property value of type ‘java.lang.String’ to required type 'java.util.Date

原因:因为前端传到后台的是字符串,而Java类属性的Date日期类型,此时需要@DateTimeFormat注解即可,但是注意用法:

@DateTimeFormat注解
①如果前端传过来是年月日
/**
* 生日
*/
@DateTimeFormat(pattern = "yyyy-MM-dd")
private Date eBirthday;
②如果前端传过来是年月日 时分秒
/**
* 生日
*/
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private Date eBirthday;
@JsonFormat注解

分Get和Post请求,两种不同的情况

Ⅰ、Get请求

Get方式传参 是 没有时区的影响

@JsonFormat的作用: 返回给前端的时间是经过@JsonFormat格式化的时间。

@DateTimeFormat的作用: 前端需要按照@DateTimeForma的格式进行传参

示例:

Date 类型直接作为参数的情况

/**
* http://localhost:8080/test1?date=2019-01-18 11:11:11
*/
@RequestMapping(value = "/test1",method = RequestMethod.GET)
    @ResponseBody
    public void test1(@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") Date date){
    System.out.println(date);//Fri Jan 18 11:11:11 CST 2019
}

Date类型属性的实体类作为参数的情况

public class DateTestVO {
    private Date finishDate;
}
@RequestMapping(value = "/test2",method = RequestMethod.GET)
@ResponseBody
public void test2(DateTestVO vo){
    System.out.println(vo);
    System.out.println(vo.getFinishDate());
    return vo;
}

实体类中没有使用注解的时候

  • 返回的是没有经过格式化的时间
使用的是默认格式的入参:
http://localhost:8080/test2?finishDate=2019/01/18 11:11:11
打印日志,正常:
DateTestVO{finishDate=Fri Jan 18 11:11:11 CST 2019}
Fri Jan 18 11:11:11 CST 2019
返回的是没有经过格式化的时间:
{
    "finishDate": "2019-01-18T03:11:11.000+0000"
}

实体类中使用@JsonFormat注解的时候

@JsonFormat(pattern = “yyyy-MM-dd HH:mm:ss”,timezone=“GMT+8”)

使用的是默认格式的入参:
http://localhost:8080/test2?finishDate=2019/01/18 11:11:11
打印日志,正常:
DateTestVO{finishDate=Fri Jan 18 11:11:11 CST 2019}
Fri Jan 18 11:11:11 CST 2019
返回@JsonFormat格式的时间:
{
    "finishDate": "2019-01-18 11:11:11"
}

实体类中使用@JsonFormat和@DateTimeFormat注解的时候

可以看到使用@DateTimeFormat注解后传入的参数类型为2019-01-18 11:11:11,而不是/

@JsonFormat(pattern = “yyyy-MM-dd HH:mm:ss”,timezone=“GMT+8”)

@DateTimeFormat(pattern = “yyyy-MM-dd HH:mm:ss”)

使用@DateTimeFormat格式的入参:
http://localhost:8080/test2?finishDate=2019-01-18 11:11:11
打印日志,正常:
DateTestVO{finishDate=Fri Jan 18 11:11:11 CST 2019}
Fri Jan 18 11:11:11 CST 2019
返回@JsonFormat格式的时间:
{
    "finishDate": "2019-01-18 11:11:11"
}
Ⅱ、post请求

有时区的影响,如果不加注解打印的日志会显示时间多了八个小时,返回的结果不会多八个小时但没有格式化

@JsonFormat的作用:

1、后台接收后,没有时区的影响

2、返回给前端是格式化的时间

3、后端的入参按照@JsonFormat的格式传参(并没有使用@DateTimeFormat来格式化后端的入参)

二、日期格式比较冲突

*### Error querying database. Cause: java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String

错误原因:因为实体类是Date 类型,当你的用字符串的形式判断该字段是否为空时,会抛出该错误

解决:只判断为空即可,可使用between..and来比较时间范围

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值