在项目中使用sql语句,或者是hql语句。

HibernateCallback()

 

HibernateTemplate提供了非常多的常用方法来完成数据库的基本操作,使得持久层访问摸板化,只要创建HibernateTemplate 实例后,注入一个SessionFactory的引用就可以了.无须手动创建sessionFactory,更加智能的管理Hibernate Session,没有大量的try/catch操作
  void delete(Object entity)删除指定持久化实例 
  deleteAll(Collection entities)删除集合内全部持久化实例 
  find(String queryString)根据HQL查询字符串返回实例集合 
  findByNamedQuery(Striing QueryName)根据命名查询返回实例集合 
  Get(Class entityClass,Serializable id)割据主键加载特定持久化类的实例 
  save(Object entity)保存实例 
  saveOrUpdate(Object entity)根据实例状态,选择保存或者更新 
  update(Object entity)更新实例的状态 
  setMaxResults(int maxResults)设置分页大小 

Hibernate的复杂用法HibernateCallback
HibernateTemplate还提供一种更加灵活的方式来操作数据库,通过这种方式可以完全使用Hibernate的操作方式。HibernateTemplate的灵活访问方式是通过如下两个方法完成:

1Object execute(HibernateCallback action)
 
2List execute(HibernateCallback action)

这两个方法都需要一个HibernateCallback的实例,HibernateCallback实例可在任何有效的Hibernate数据访问中使用。
程序开发者通过HibernateCallback,可以完全使用Hibernate灵活的方式来访问数据库,解决Spring封装Hibernate后灵活性不足的缺陷。
HibernateCallback是一个接口,该接口只有一个方法doInHibernate(org.hibernate.Session session)
该方法只有一个参数Session。通常,程序中采用实现HibernateCallback的匿名内部类来获取HibernateCallback的实例,方法doInHibernate的方法体就是Spring执行的持久化操作。

 
   @SuppressWarnings({ "unchecked", "rawtypes" })
   public List<T> findByCriteria(final Class<T> entityClass,final String propertyName,final boolean isAsc,final int firstResult,final int maxResults,final Criterion... criterions){
       List<T> list = (List<T>)getHibernateTemplate().execute(new HibernateCallback(){

            public Object doInHibernate(Session session)
                   throws HibernateException, SQLException {
               Criteria criteria = session.createCriteria(entityClass);
               //按属性条件查询
               for(Criterion criterion : criterions){
                   criteria.add(criterion);
               }
               //按某个属性排序
               if(null != propertyName){
                   if(isAsc){
                       criteria.addOrder(Order.asc(propertyName));//升序
                   }else{
                       criteria.addOrder(Order.desc(propertyName));
                   }
               }
               //用于分页查询
               if(maxResults != 0){
                   criteria.setFirstResult(firstResult);
                   criteria.setMaxResults(maxResults);
               }
               List<T> list = criteria.list();
               return list;
           }
       });
       return list;
   }
  
  
   @SuppressWarnings({ "unchecked", "rawtypes" })
public int findCountsByCriteria(final Class<T> entityClass,final Criterion... criterions){
           int totalCounts = (Integer)getHibernateTemplate().execute(new HibernateCallback(){

            public Object doInHibernate(Session session)
                   throws HibernateException, SQLException {
               Criteria criteria = session.createCriteria(entityClass);
               //按属性条件查询
               for(Criterion criterion : criterions){
                   criteria.add(criterion);
               }
               int totalCounts = criteria.list().size();
               return totalCounts;
           }
       });
       return totalCounts;
   }
  
        做分页:
public List findByPage(final String hql,
       final int offset, final int pageSize)
   {
       //通过一个HibernateCallback对象来执行查询
       List list = getHibernateTemplate()
           .executeFind(new HibernateCallback()
       {
           //实现HibernateCallback接口必须实现的方法
           public Object doInHibernate(Session session)
               throws HibernateException, SQLException
           {
               //执行Hibernate分页查询
               List result = session.createQuery(hql)
                   .setFirstResult(offset)
                   .setMaxResults(pageSize)
                   .list();
               return result;
           }
       });
       return list;
   }

   
   public List findByPage(final String hql , final Object value ,
       final int offset, final int pageSize)
   {
       //通过一个HibernateCallback对象来执行查询
       List list = getHibernateTemplate()
           .executeFind(new HibernateCallback()
       {
           //实现HibernateCallback接口必须实现的方法
           public Object doInHibernate(Session session)
               throws HibernateException, SQLException
           {
               //执行Hibernate分页查询
               List result = session.createQuery(hql)
                   //hql语句传入参数
                   .setParameter(0, value)
                   .setFirstResult(offset)
                   .setMaxResults(pageSize)
                   .list();
               return result;
           }
       });
       return list;
   }

   
   public List findByPage(final String hql, final Object[] values,
       final int offset, final int pageSize)
   {
       //通过一个HibernateCallback对象来执行查询
       List list = getHibernateTemplate()
           .executeFind(new HibernateCallback()
       {
           //实现HibernateCallback接口必须实现的方法
           public Object doInHibernate(Session session)
               throws HibernateException, SQLException
           {
               //执行Hibernate分页查询
               Query query = session.createQuery(hql);
               //hql语句传入参数
               for (int i = 0 ; i < values.length ; i++)
               {
                   query.setParameter( i, values[i]);
               }
               List result = query.setFirstResult(offset)
                   .setMaxResults(pageSize)
                   .list();
               return result;
           }
       });
       return list;
   }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值