使用SQL将数据库中的日期Java与DateTime列进行比较

前端之家收集整理的这篇文章主要介绍了使用SQL将数据库中的日期Java与DateTime列进行比较前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我有两个Date Java对象,它们将被分配给SQL查询中的一些变量(因为我使用Hibernate),以便将它们与DateTime类型列进行比较,以获得具有指定时间范围的行,例如:

  WHERE event_date >= :startDate and event_date < :finishDate

我无法直接比较日期和日期时间,所以我想到了两个可能的解决方案:

>尝试在比较之前使用查询日期字段转换event_date字段.
>或者尝试将date java对象转换为dateTime,我认为这可能是不可能的..

你建议我做什么?

最佳答案
我猜你有问题,因为你使用setDate(如果我错了,请纠正我)和setDate方法

Binds the date (time is truncated) of a given Date object to a named query parameter.

请改用setTimestamp,它绑定给定Date对象的日期和时间:

java.util.Date startDate = … ;
java.util.Date finishDate = … ;
Query query = session.createQuery("from YourTable where event_date >= :startDate and event_date < :finishDate");
query.setTimestamp("startDate",startDate);
query.setTimestamp("finishDate",finishDate);

p.s.:一定要使用java.util.Date对象而不是java.sql.Date对象.

猜你在找的Java相关文章