HIbernate中通过Query.setDate()查询得到的数据有问题,具体如下:
Query query = session.createQuery("from Member where createDate >=?");
query.setDate(0, new Date());
查询得到结果不到正确的数据,在数据库中通过sql语句查询:
select * from member
where create_date>='2007-07-13 19:56:00' 能
得到正确的结果;
因为Query的setDate()方法赋值的时候,HIbernate默认把赋值日期后面的时分秒截取掉,只留下年月日,如
果只是通过">" or "<" 进行日期比较完全Okey,但是带上"="就不行了,有三种方法可以解决这个问题。
其一、通过setCalendar()赋值
其二、通过setTimestamp()赋值
其三、拼接字符串。String hql="from Member where createDate ='"+(new Date())+"'";
Hibernate Query.setDate()问题及解决
本文探讨了在使用Hibernate的Query.setDate()方法时遇到的问题,即无法正确地使用带有等号的日期条件进行查询。文章提供了三种解决方案:使用setCalendar()、setTimestamp()以及字符串拼接,并详细解释了每种方法的应用场景。
875

被折叠的 条评论
为什么被折叠?



