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())+"'";