用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 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |
你可能对下面的文章感兴趣
关于用hibernate查询一段时间的记录 - 编程入门网的所有评论