论坛首页 Java企业应用论坛

Hiberante3 setDate() Problem

浏览 1991 次
该帖已经被评为隐藏帖
作者 正文
   发表时间:2007-08-25  
      今天在工作中遇见一个问题:
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()方法了.
 
 
论坛首页 Java企业应用版

跳转论坛:
Global site tag (gtag.js) - Google Analytics