`

getHibernateTemplate().execute(new HibernateCallback())方法

阅读更多

1. HibernateCallback是一个接口,该接口只有一个方法doInHibernate(org.hibernate.Session session),该方法

 

只有一个参数 Session。

 

2. 方法 doInHibernate 的方法体就是 Spring执行的持久化操作。

 

3. 使用HibernateTemplate执行execute(new HibernateCallback())方法,从HibernateCallback中得到session,

 

在此session中做多个操作,并希望这些操作位于同一个事务中。

 

4. 回调实际就是一种事件触发模式,就象连环地雷一样,一旦触发一个,这个再触发另外一个,你在find这个方法被执行

 

时,希望同时执行其他方法,就需要回调。

 

例如:

          return (List<E>) getHibernateTemplate().execute(
                new HibernateCallback() {
                        public Object doInHibernate(Session session)
                              throws HibernateException {
                                          Criteria criteria = session.createCriteria(entityClass);
                                          criteria.setFirstResult(pageSize * (pageIndex));
                                          criteria.setMaxResults(pageSize);
                                          return criteria.list();
                               }
    }); 

 

 

如例子代码中,他希望在执行execute()时也执行HibernateCallback 中的一些方法。

 

5. HibernateTemplate提供这个HibernateCallback,
          就是为了满足这种使用了HibernateTemplate的情况下,
          仍然需要直接访问Session的需求而来的
          它提供了在HibernateTemplate里面直接访问Session的能力
          这个就是我们要使用HibernateCallback的原因.

 

6  需要在hibernate中写连接多个表的sql语句

 

    final  String  sql = "select  textvalue  from  a";
  List   list = (List)this.getHibernateTemplate().execute(new org.springframework.orm.hibernate.HibernateCallback(){
   public Object doInHibernate(Session session) throws HibernateException, SQLException {
               Connection con = session.connection(); 
                 PreparedStatement ps = con.prepareStatement(sql); 
                 ResultSet rs = ps.executeQuery(); 
                 List all = new ArrayList();
                 while(rs.next()){ 
                   String  result = (String)rs.getString("textvalue");
                   all.add(result);
                 } 
                 rs.close(); 
                 ps.close(); 
                 session.flush(); 
                 session.close(); 
                 return all; 
   }
     });

分享到:
评论

相关推荐

    hibernate执行原生sql语句

    return getHibernateTemplate().execute(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException, SQLException { Connection conn = session.connection(); ...

    shh整合框架实现分页

    return (List) super.getHibernateTemplate().execute(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException, SQLException { Query query = session.createQuery...

    常用的HQL语句!!!!

    this.getHibernateTemplate().execute(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException, SQLException { return session.createQuery(hql).executeUpdate();...

    JspWeb开发CRUD 操作

    return (List) getHibernateTemplate().execute(new HibernateCallback(){ public Object doInHibernate(Session session) throws HibernateException{ List result = session.createCriteria(Address.class).add...

    struts+spring+hibernate通用分页方法

    return (PageSupport) getHibernateTemplate().execute( new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException, SQLException { Criteria criteria = cq....

    spring_MVC源码

    弃用了struts,用spring mvc框架做了几个项目,感觉都不错,而且使用了注解方式,可以省掉一大堆配置文件。本文主要介绍使用注解方式配置的spring mvc,之前写的spring3.0 mvc和rest小例子没有介绍到数据层的内容,...

    ssh实例 集成 例子

    return getHibernateTemplate().execute(new HibernateCallback&lt;List&lt;String&gt;&gt;() { @Override public List&lt;String&gt; doInHibernate(Session session) throws HibernateException, SQLException { Query query = ...

    HibernateTemplate类的使用

    CtxUtil.getBaseManager().getHibernateTemplate().execute(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException, SQLException { // 保存stu1 Student stu1 = ...

    spring+hibernate详解

    return (List) getHibernateTemplate().execute(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException { Criteria criteria = session.createCriteria(Person....

    ssh 框架完全整合笔记

    return (Student) getHibernateTemplate().execute(new HibernateCallback() { @Override public Student doInHibernate(Session session) throws HibernateException { // ... 查询逻辑 ... } }); } } ``` ...

    spring hibernatetemplate

    在`HibernateTemplate`中执行事务操作通常涉及到`execute`方法,该方法接受一个实现了`HibernateCallback`接口的匿名类实例作为参数。`HibernateCallback`的`doInHibernate`方法会在Hibernate的Session上下文中执行...

    Struts+Spring+Hibernate 简单例子开发

    return getHibernateTemplate().execute(new HibernateCallback&lt;List&lt;User&gt;&gt;() { public List&lt;User&gt; doInHibernate(Session session) throws HibernateException, SQLException { Query query = session....

    hibernate API

    虽然`HibernateTemplate`提供了很多便利,但它在处理复杂查询时可能需要创建内部类(inner class),如在分页查询时使用`execute(HibernateCallBack)`,这可能会增加调试的复杂性。相比之下,直接使用`Session`进行...

    SSH整合文档

    HibernateCallback&lt;List&lt;Dept&gt;&gt; callback = new HibernateCallback&lt;List&lt;Dept&gt;&gt;() { @Override public List&lt;Dept&gt; doInHibernate(Session session) throws HibernateException, SQLException { Query query = ...

    第24次课-1 Spring与Hibernate的整合

    通常,程序中采用实现HibernateCallback的匿名内部类来获取HibernateCallback的实例,方法doInHibernate()就是Spring执行的持久化操作。 24.3 Spring对Hibernate的简化 24.3.5 HibernateDaoSupport Spring为与...

    Oracle存储过程

    如示例所示,通过`getHibernateTemplate().execute()`方法传递一个`HibernateCallback`,然后在回调方法中创建并执行`CallableStatement`。这使得在Java应用程序中直接调用数据库的存储过程成为可能,提高性能并简化...

    ssh2分页代码

    return getHibernateTemplate().executeFind(new HibernateCallback&lt;List&lt;Member&gt;&gt;() { public List&lt;Member&gt; doInHibernate(Session session) throws HibernateException, SQLException { Query query = session....

    ssh(structs,spring,hibernate)框架中的上传下载

    HibernateDaoSupport封装了HibernateTemplate,而HibernateTemplate封装了Hibernate所提供几乎所有的的数据操作方法,如execute(HibernateCallback action),load(Class entityClass, Serializable id),save(final ...

    HibernateSpringStruts2整合开发中的一个分页显示方案.doc

    在`queryForPage`方法中,我们使用了`HibernateCallback`接口回调,通过`getHibernateTemplate().executeFind()`执行HQL查询并设置分页参数`setFirstResult`和`setMaxResults`。`getAllRowCount`方法则直接返回HQL...

Global site tag (gtag.js) - Google Analytics