Parameter value [2024-04-20] did not match expected type [java.util.Date (n/a)];报错分析

报错:

报错解释:

这个报错信息表明查询方法期望的参数类型是java.util.Date,但是传入的参数值2024-04-20被解析为一个字符串。由于JPA或者Hibernate不能直接将字符串转换为java.util.Date类型,所以抛出了类型不匹配的异常。

解决方法:

确保传递给查询方法的日期参数是java.util.Date类型的实例。如果你是通过查询方法传递参数的,可以通过以下方式进行转换:

1、如果你使用的是查询DSL(如JPA Criteria API),你需要创建一个java.util.Date实例,并将字符串转换为日期格式。 

SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
Date date = dateFormat.parse("2024-04-20");

2、如果你是通过在查询中直接传递参数,确保参数是java.util.Date类型。如果你使用的是Spring Data JPA,可以在查询方法上使用@Param注解来传递参数,并确保参数是正确的类型。

public interface YourRepository extends JpaRepository<YourEntity, Long> {
    List<YourEntity> findByDate(@Param("date") Date date);
}

然后在调用的地方:

SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
Date date = dateFormat.parse("2024-04-20");
List<YourEntity> results = yourRepository.findByDate(date);

确保你的实体类中的日期字段使用了正确的注解,例如@Temporal,以便正确映射到数据库。

  • 7
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值