Hibernate Query在日期上提取记录而忽略时间戳

时间:2010-10-25 09:24:33

标签: java hibernate persistence hql

我在其中一个DB(Oracle)表中有一个时间戳列交换。 我使用hibernate作为持久层来获取数据并将数据存储到数据库。 我有一个要求,我需要在日期查询数据库。 即从UI用户传递日期,我需要根据此日期获取过滤后的数据。

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

例如:说2010年10月23日在DB 5中有10条记录有时间戳条目,5条没有

所以我的查询只返回了没有时间戳的5行。

现在我知道我需要从时间戳中提取日期然后进行比较,以便我获得特定日期的所有记录,但我不知道它是如何使用Hibernate并使用HQL

我正在使用的 Java / Hibernate 中的查询如下

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

1 个答案:

答案 0 :(得分: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);