`
hotforcc
  • 浏览: 61292 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Hiberante3 setDate() Problem

 
阅读更多
      今天在工作中遇见一个问题:
java 代码
  1. Date beginTime=null;   
  2. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");try {   
  3. beginTime= sdf.parse('2007-07-13 19:56:00');   
  4.   
  5. Query query = session.createQuery("from OrderAmountBasedPromotion as     
  6. promotion where promotion.begintime =:TIME and promotion.amountGreaterThan  
  7. :AMOUNT");   
  8. query.setDate("TIME", beginTime);   
  9. query.setFloat("AMOUNT", Float.valueOf("99.0"));  
       的时候老是查询不到正确的数据,在数据库中
sql 代码
  1. 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 代码
  1. Date beginTime=null;   
  2. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");try {   
  3. beginTime= sdf.parse('2007-07-13 19:56:00');   
  4.   
  5. Calendar cal = Calendar.getInstance();   
  6. cal.setDate(beginTime);   
  7. query.setCalendar("TIME", cal );   
  8. query.setFloat("AMOUNT", Float.valueOf("99.0"));   
 
Good ,Pass
最终结论是Hibernate的Query的setDate()方法只会保留日期数据,而对时间部分会遗失,如果在做>或者<之类的时间比较的情况下,不会有什么大的影响,而一旦where 我们用=的时候并且精确到秒的时候,这个时候就需要用到setCalendar()方法了.
 
 
分享到:
评论

相关推荐

    hiberante3 注解帮助文档

    hiberante3 注解帮助文档hiberante3 注解帮助文档hiberante3 注解帮助文档hiberante3 注解帮助文档hiberante3 注解帮助文档

    Hiberante3.jar + API

    《Hibernate3.jar与API详解》 Hibernate,作为一个强大的对象关系映射(ORM)框架,是Java开发者在处理数据库操作时的得力助手。本篇将深入探讨Hibernate3.jar及其API,帮助开发者更好地理解和运用这个库。 一、...

    Hiberante3相关文档

    标题“Hiberante3相关文档”表明了主要讨论的是关于Hibernate3这一持久化框架的资料集合,可能涵盖了多个方面,如查询语言、缓存机制以及数据加载策略。 描述中的“Hiberante3_HQL”提示我们将会涉及到Hibernate...

    hiberante-4.2.3-part3

    hiberante-4.2.3-part3

    DAO层中对Hiberante

    3. `beginTransaction()`:启动一个新的数据库事务。在开始事务后,所有的数据库操作都在这个事务的范围内进行,直到事务被提交或回滚。 4. `endTransaction(boolean success)`:根据参数`success`决定是否提交事务...

    最新springboot2hiberante5项目

    最新springboot2基础hiberante5完整项目,打包jar,运行jsp,包括后台与前台,拦截器,登录,后台下载就可以使用,注意不是jpa,里面有完整Dao,千万级数据项目分离的代码,为了适合老项目开发特意集成hiberante5....

    hiberante 源码 配置资料

    3. 数据库交互:Hibernate通过JDBC进行数据库操作,`org.hibernate.engine.jdbc`包下包含了对JDBC的封装。例如,ConnectionProvider负责数据库连接的获取和释放,而StatementExecutor处理SQL执行。 4. 查询机制:...

    Hiberante 有关jar包

    Hibernate Tools是一套全新而且完整的面向Hibernate3的工具集合,它包含了Eclipse插件和Ant编译流程。Hibernate Tools是JBoss Tools的核心组件,所以他也是JBoss Developer Studio的一部分

    spring+mvc+hiberante

    Spring 框架是 Java 企业级应用开发中的核心组件,它提供了全面的软件基础设施,包括依赖注入(DI)、面向切面编程(AOP)以及众多的模块如数据访问、Web 应用、任务调度等。Spring MVC 是 Spring 框架的一部分,...

    疯狂Ajax讲义3+Spring+hiberante

    《疯狂Ajax讲义3》是针对Web开发领域中Ajax技术的深入学习资料,结合Spring和Hibernate两大框架,为读者提供...通过阅读《疯狂Ajax讲义3+Spring+hiberante》,你将能够掌握这一现代Web开发技术栈,提升自己的专业技能。

    hiberante5.0.7安装jar包

    3. **hibernate-validator.jar**: 实现了JSR-303/JSR-349 Bean Validation标准,用于验证实体属性的值是否符合预定义的约束。 4. **jta.jar**: 为了支持分布式事务处理,Hibernate依赖于Java Transaction API(JTA...

    Struts+Hiberante+Sprint 框架整合

    开发工具:MyEclipse 6....Struts+Spring+Hiberante框架整合的简单登录系统 无需配置任何文件、只需在mysql中创建一个空数据库 如:create database test; 注:mysql数据库用户名:root 密码:root

    struts2.0+spring2.0+hiberante3+dwr+freemarker整合所需jar包

    Struts2.0、Spring2.0、Hibernate3和DWR以及Freemarker是Java Web开发中的关键组件,它们各自负责不同的职责,并且通过合理的整合,可以构建出强大的企业级应用系统。 Struts2.0是Apache软件基金会下的一个开源MVC...

    hiberante4.2.3-part2

    hiberante4.2.3-part2

    springmvc hiberante

    3. 拦截器:Spring MVC的Interceptor可以拦截请求,执行预处理和后处理逻辑,如权限验证、日志记录、性能统计等。定义一个实现了HandlerInterceptor接口的类,并在Spring MVC配置中注册。 4. 日志记录:Spring MVC...

    Hiberante中的五大核心接口.txt

    ### Hibernate中的五大核心接口 #### 一、概述 在Hibernate框架中,存在五大核心接口,它们分别是:`Session`、`SessionFactory`、`Transaction`、`Query` 和 `Configuration`。这些接口对于Hibernate的正常运行至...

    hiberante-4.2.3-part4

    hiberante-4.2.3-part4

    hiberante查询方式使用详解

    在Java世界中,Hibernate是一个非常流行的ORM(对象关系映射)框架,它允许开发者使用面向对象的方式来操作数据库,而无需关心底层SQL语句的编写。本文将深入探讨Hibernate的四种主要查询方式:HQL(Hibernate Query...

    hiberante 代码save方法过程,分析

    hiberante 代码save方法过程,分析

    hiberante3.2纯静源码

    hiberante3.2纯静源码

Global site tag (gtag.js) - Google Analytics