我有两个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对象.