今天在工作中遇见一个问题:
java 代码
- Date beginTime=null;
- SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");try {
- beginTime= sdf.parse('2007-07-13 19:56:00');
-
- Query query = session.createQuery("from OrderAmountBasedPromotion as
- promotion where promotion.begintime =:TIME and promotion.amountGreaterThan
- :AMOUNT");
- query.setDate("TIME", beginTime);
- query.setFloat("AMOUNT", Float.valueOf("99.0"));
的时候老是查询不到正确的数据,在数据库中
sql 代码
- select * from order_amount_based_promotiom where begin_time=to_date('2007-07-13 19:56:00','yyyy-MM-dd HH24:mi:ss' and amount_greater_than>99
明明在数据库中可以查询到的.于是一点点的怀疑,开始怀疑是setDate这个函数是不是丢失了时间:分钟:秒数据,开始 查询Query的API,发现还有个setCalendar()方法,开始做以下测试:
java 代码
- Date beginTime=null;
- SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");try {
- beginTime= sdf.parse('2007-07-13 19:56:00');
-
- Calendar cal = Calendar.getInstance();
- cal.setDate(beginTime);
- query.setCalendar("TIME", cal );
- query.setFloat("AMOUNT", Float.valueOf("99.0"));
Good ,Pass
最终结论是Hibernate的Query的setDate()方法只会保留日期数据,而对时间部分会遗失,如果在做>或者<之类的时间比较的情况下,不会有什么大的影响,而一旦where 我们用=的时候并且精确到秒的时候,这个时候就需要用到setCalendar()方法了.
分享到:
相关推荐
hiberante3 注解帮助文档hiberante3 注解帮助文档hiberante3 注解帮助文档hiberante3 注解帮助文档hiberante3 注解帮助文档
Hiberante3.jar + API
Hiberante3_HQL,Hibernate3_缓存机制,Hibernate3_数据加载
DAO层中对Hiberante实例,大家交流一下
struts2.0 +spring2.0+hiberante3所需jar包
hiberante-4.2.3-part3
最新springboot2基础hiberante5完整项目,打包jar,运行jsp,包括后台与前台,拦截器,登录,后台下载就可以使用,注意不是jpa,里面有完整Dao,千万级数据项目分离的代码,为了适合老项目开发特意集成hiberante5....
疯狂Ajax讲义3+Spring+hiberante
hiberante查询方式使用详解,有hql,sql,qbc,以及存储过程,hiberante的基础查询
Hibernate Tools是一套全新而且完整的面向Hibernate3的工具集合,它包含了Eclipse插件和Ant编译流程。Hibernate Tools是JBoss Tools的核心组件,所以他也是JBoss Developer Studio的一部分
hibernate 源码 和hibernate配置的html文档。。非常全面的介绍了hibernate配置。分别在src和zh-cn文件中
spring整合
Hiberante HTML 帮助文档 Hiberante HTML 帮助文档 Hiberante HTML 帮助文档
Struts2+hiberante+Spring+Extjs+OA办公系统,完整包正常运行
hibernate5.0.7jar包,主要是jar包,方便大家下载使用。主要是jar包,方便大家下载使用。主要是jar包,方便大家下载使用
开发工具:MyEclipse 6....Struts+Spring+Hiberante框架整合的简单登录系统 无需配置任何文件、只需在mysql中创建一个空数据库 如:create database test; 注:mysql数据库用户名:root 密码:root
spring4+hiberante4+struts2+maven最新框架
hiberante4.2.3-part01
hiberante4.2.3-part2
hiberante annotations reference_cn