快速业务通道

用hibernate查询一段时间的记录 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-13

用hibernate查询一段时间的记录

时间:2012-01-28 BlogJava duduli

这是在一个群里讨论的问题。

方法很多:如果说数据库中数据的存储是用date类型的话,改怎么做,如果说做数据迁移的话又该怎么做?

最终的讨论方案在用字符串存储格式上比较好,毕竟各个数据库对时间的存储存在差异。

一下是我用hibernate中的HQL,和QBC两种检索方式对一段时间内的数据进行检索。

 1 package com.duduli.li;

 2 

 3 import java.util.Date;

 4 import java.util.Iterator;

 5 import java.util.List;

 6 

 7 import org.hibernate.Criteria;

 8 import org.hibernate.Session;

 9 import org.hibernate.Transaction;

10 import org.hibernate.criterion.Criterion;

11 import org.hibernate.criterion.Expression;

12 

13 public class Select {

14 

15     /**

16      * @param args

17      */

18     public static void main(String[] args) {

19         // TODO Auto-generated method stub

20         Session session = HibernateSessionFactory.getSession();

21         Transaction tran = session.beginTransaction();

22 /*        

23  *         采用HQL的方式,

24         Date begin = java.sql.Date.valueOf("2009-03-24");

25         Date end = java.sql.Date.valueOf("2009-03-26");

26         List<A> result = session.createQuery("from A a where a.date > :beginTime and a.date <= :endTime").setTimestamp("beginTime", begin).setTimestamp("endTime", end).list();

27         for(A a : result){

28                 System.out.println(a.getId());

29                 System.out.println(a.getTitle());

30                 System.out.println(a.getDate());

31         }

32         */

33         

34 //        采用QBC的方式。

35         Date begin = java.sql.Date.valueOf("2009-3-24");

36         Date end = java.sql.Date.valueOf("2009-3-26");

37         Criteria criteria = session.createCriteria(AbstractA.class);

38         Criterion creterion = Expression.between("date", begin, end);

39         List<A> result = criteria.add(creterion).list();

40         for(A a : result){

41             System.out.println(a.getId());

42             System.out.println(a.getTitle());

43             System.out.println(a.getDate());

44         }

45     }

46 }

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号