Hibernate3 Query setDate() 问题

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

 

你可能感兴趣的:(sql,Hibernate)