[英]Compare Date Java to DateTime Column in database table using SQL
我有两个Date
Java对象,它们将被分配给sql查询中的一些变量(因为我使用Hibernate),以便将它们与DateTime
类型列进行比较,以获得具有指定时间范围的行,例如:
WHERE event_date >= :startDate and event_date < :finishDate
我无法直接比较日期和日期时间,所以我想到了两个可能的解决方案:
你建议我做什么?
我猜你有问题,因为你使用setDate
(如果我错了,请纠正我)和setDate
方法:
将给定
Date
对象的日期(时间被截断)绑定到命名查询参数。
请改用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);
ps:一定要使用java.util.Date
对象而不是 java.sql.Date
对象。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.