{转}HibernateCallback

本文介绍如何利用HibernateTemplate结合HibernateCallback进行数据库操作,展示了如何通过匿名内部类实现复杂的查询逻辑。

今天项目中用到了,HibernateCallback。以前没用过,也不知道这样做的作用有多大。上来存档一下。

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

q      Object execute(HibernateCallback action)

q      List execute(HibernateCallback action)

这两个方法都需要一个HibernateCallback的实例,HibernateCallback实例可在任何有效的Hibernate数据访问中使用。程序开发者通过HibernateCallback,可以完全使用Hibernate灵活的方式来访问数据库,解决Spring封装Hibernate后灵活性不足的缺陷。HibernateCallback是一个接口,该接口只有一个方法doInHibernate(org.hibernate.Session session),该方法只有一个参数Session。

通常,程序中采用实现HibernateCallback的匿名内部类来获取HibernateCallback的实例,方法doInHibernate的方法体就是Spring执行的持久化操作。具体代码如下:

public class PersonDaoImpl implements PersonDao

{

    //私有实例变量保存SessionFactory

         private SessionFactory sessionFactory;

         //依赖注入必须的setter方法

    public void setSessionFactory(SessionFactory sessionFactory)

         {

           this.sessionFactory = sessionFactory;

    }

         /**

         * 通过人名查找所有匹配该名的Person实例

         * @param name 匹配的人名

         * @return 匹配该任命的全部Person集合

         */

    public List findPersonsByName(final String name)

         {

           //创建HibernateTemplate实例

                   HibernateTemplate hibernateTemplate =

                         new HibernateTemplate(this.sessionFactory);

           //返回HibernateTemplate的execute的结果

                   return (List) hibernateTemplate.execute(

                //创建匿名内部类

                   new HibernateCallback()

                   {

              public Object doInHibernate(Session session) throws HibernateException

                            {

                   //使用条件查询的方法返回

                                     List result = session.createCriteria(Person.class)

                                                                     .add(Restrictions.like(“name”, name+”%”)

                                                                           .list();

                                    return result;

                     }

                });

    }

}

注意:方法doInHibernate方法内可以访问Session,该Session对象是绑定到该线程的Session实例。该方法内的持久层操作,与不使用Spring时的持久层操作完全相同。这保证对于复杂的持久层访问,依然可以使用Hibernate的访问方式。

 

 项目中的源码:

public List getAllByClient(final Client client, final int first, final int pageSize) {      

        List result = (List) this.getHibernateTemplate().execute(            new HibernateCallback() {

     @Override         

public Object doInHibernate(Session session)     

       throws HibernateException, SQLException {           

 List tmp = session.createQuery(          "from Album as ab where ab.client=:client")   

      .setEntity("client", client).setFirstResult(           first).setMaxResults(pageSize).list();    

   return tmp;   

  }

    });   return result;  }

 

本文来自优快云博客,转载请标明出处:http://blog.youkuaiyun.com/Luo2008wei/archive/2008/07/04/2610898.aspx

根据上述 String hql = "from " + OrderDetail.class.getName() + " orderDetail where orderDetail.delFlag= 0 and orderDetail.orderNo != 'New' "; String hqlCenter = " and exists (from " + Order.class.getName() + " orders where orders.delFlag= 0 and orders.releaseStatus = 'Close' " + " and orderDetail.orderNo = orders.orderNo and orderDetail.createdByCompany = orders.createdByCompany"; String hqlEnd = ") order by TO_NUMBER(ORDER_ITEM_INDEX) asc, orderDetail.createdTime desc "; final List paramList = new ArrayList(); // 是否模糊查询 boolean isFuzzySearch = false; if (StrUtil.isNotBlank(searchOrderForm.getIsFuzzySearch()) && OmsConstant.IS_FUZZY_SEARCH.equals(searchOrderForm.getIsFuzzySearch())) { isFuzzySearch = true; } if (ObjectUtil.isNotEmpty(searchOrderForm)) { // 条件拼接 orderNo if (StrUtil.isNotEmpty(searchOrderForm.getOrderNo())) { if (isFuzzySearch) { //sql语句;查询数据库别名;实体类属性名;参数;list对象 hql = SqlUtil.addLikeSqlCondition(hql, "orderDetail", "orderNo", searchOrderForm.getOrderNo(), paramList); } else { //sql语句;查询数据库别名;实体类属性名;参数;list对象 hql = SqlUtil.addEqSqlCondition(hql, "orderDetail", "orderNo", searchOrderForm.getOrderNo(), paramList); } } // 只查询 Close 状态的 } final String finalHql = hql + hqlCenter + hqlEnd; List<OrderDetail> orderList = (List<OrderDetail>) getHibernateTemplate().execute(new HibernateCallback() { @Override public Object doInHibernate(Session arg0) throws HibernateException, SQLException { Query query = getSession().createQuery(finalHql); if (CollUtil.isNotEmpty(paramList)) { for (int i = 0; i < paramList.size(); i++) { query.setParameter(i, paramList.get(i)); } } ps.setTotalCount(query.list().size()); query.setFirstResult(ps.getStartIndex()); query.setMaxResults(ps.getCountOnEachPage()); return query.list(); } }); this.setOrderDetailDeliveryQtyOpenQty(orderList); ps.setItems(orderList); return ps; }怎么改 标注出修改地方
最新发布
10-21
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值