hibernate——两种查询方式

一种是hql语句查询,用Query接口去实现;一种是条件查询,用Criteria接口去实现。这两种方式作用差不多,只是后者更符合面向对象一些。

用hql语句查询,如下例:

  1. public static void query(String name){  
  2.           
  3.         Session session=null;  
  4.         try{  
  5.             session=HibernateUtil.getSession();  
  6.               
  7.             //String hql1="from User as user where user.name=?";  
  8.             //Query query=session.createQuery(hql1);  
  9.             //query.setString(0, hql1);  
  10.               
  11.             String hql2="from User as user where user.name=:username";//使用命名参数  
  12.             Query query=session.createQuery(hql2);  
  13.             query.setString("username", name);  
  14.               
  15.             query.setFirstResult(0);  
  16.             query.setMaxResults(10);//查询分页  
  17.               
  18.             List<User> list = query.list();  
  19.               
  20.             for(User user:list){  
  21.                 System.out.println(user.getName());  
  22.             }  
  23.         }catch(HibernateException e){  
  24.             e.printStackTrace();  
  25.         }finally{  
  26.             if(session!=null){  
  27.                 session.close();  
  28.             }  
  29.         }  
  30.     }  


使用条件查询,如下例:

  1. public static void criteria(String name){  
  2.         Session session=null;  
  3.         try{  
  4.             session=HibernateUtil.getSession();  
  5.               
  6.             Criteria criteria=session.createCriteria(User.class);//条件查询  
  7.             criteria.add(Restrictions.eq("name", name));//增加约束条件,第一个参数是对象中的属性名,后一个是查询条件,eq就是equals的意思  
  8.             criteria.add(Restrictions.lt("birthday"new Date()));//lt是less than,即小于的意思  
  9.               
  10.             List<User> list = criteria.list();  
  11.               
  12.             //User user=(User)criteria.uniqueResult();//若查询结果只有一个的话,那么用这个方法也可以  
  13.               
  14.             for(User user:list){  
  15.                 System.out.println(user.getName()+" "+user.getBirthday());  
  16.             }  
  17.         }catch(HibernateException e){  
  18.             e.printStackTrace();  
  19.         }finally{  
  20.             if(session!=null){  
  21.                 session.close();  
  22.             }  
  23.         }  
  24.     }  

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值