繁体   English   中英

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

[英]Compare Date Java to DateTime Column in database table using SQL

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

  WHERE event_date >= :startDate and event_date < :finishDate

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

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

你建议我做什么?

我猜你有问题,因为你使用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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM