2010-10-25 41 views
2

我有一个时间戳列在一个DB(Oracle)表中交易。 我使用hibernate作为持久层来获取数据并将其存储到数据库。 我有一个需求,我需要在日期查询数据库。 即从用户界面用户传递一个日期,我需要基于这个日期获取过滤的数据。休眠查询获取日期时忽略时间戳的记录

如果被交易的专栏只有日期部分,我的查询返回正确的记录 当交易的专栏填充了时间戳值,即(日期+时间)时,就会出现问题。然后这些值不会被查询返回。

如:说有在DB 5 10条于2010年10月23日的他们有时间戳项和5不

所以,我有我的回报只有5行,其不具有时间戳查询。

现在我知道我需要从时间戳提取日期,然后做对比,这样我得到aprticular日期的所有记录,但我不知道它与Hibernate如何完成和使用HQL

查询中Java /休眠我使用的是如下

字符串hql =“选择从POJO清除POJO POJO.tradeDate =:date”; Query query = getSession()。createQuery(hql); query.setParameter(“date”,date);

+0

这可能会帮助 - http://stackoverflow.com/questions/980366/using-hql-to-query-on-a -date-while-ignore-the-time-on-oracle – William 2010-10-25 09:40:44

回答

9
String hql = "from POJO as POJO where to_date(to_char(POJO.tradeDate, 'DD-MON-YY'), 'DD-MON-YY') = :date"; 
Query query = getSession().createQuery(hql); 
query.setParameter("date", date); 

[编辑]

当心,指数,如果有任何,在tradeDate如果你按照上面的查询将不会被使用。在情况下,也有一些性能问题,你可以比较像这样做,

String hql = "from POJO as POJO where POJO.tradeDate between :date and :ceilDate"; 
Query query = getSession().createQuery(hql); 
// a date having timestamp part, 00:00:00.0, or missing completely 
query.setParameter("date", date); 
// a date having timestamp part, 23:59:59.999 
query.setParameter("ceilDate", ceilDate); 
+0

非常感谢Adeel!它帮助我解决了问题 – Arun 2010-10-25 12:04:23