程序问答   发布时间:2022-06-02  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Hibernate查询以忽略时间戳的日期获取记录大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决Hibernate查询以忽略时间戳的日期获取记录?

开发过程中遇到Hibernate查询以忽略时间戳的日期获取记录的问题如何解决?下面主要结合日常开发的经验,给出你关于Hibernate查询以忽略时间戳的日期获取记录的解决方法建议,希望对你解决Hibernate查询以忽略时间戳的日期获取记录有所启发或帮助;
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);

解决方法

我在DB(Oracle)表之一中有一个timestamp列tradedate。我使用hibernate作为持久层来获取数据并将其存储到DB。我有一个需要查询日期的数据库的要求。即从用户界面传递一个日期,我需要根据该日期获取过滤后的数据。

如果tradedate列仅包含日期部分,我的查询将返回正确的记录。当在tradedate列中填充时间戳值即(日期+时间)时,就会出现此问题。然后,查询不会返回这些值。

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

因此,我有查询只返回5没有时间戳的行。

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

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

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

大佬总结

以上是大佬教程为你收集整理的Hibernate查询以忽略时间戳的日期获取记录全部内容,希望文章能够帮你解决Hibernate查询以忽略时间戳的日期获取记录所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: