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;
}
});
分享到:
相关推荐
return getHibernateTemplate().execute(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException, SQLException { Connection conn = session.connection(); ...
return (List) super.getHibernateTemplate().execute(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException, SQLException { Query query = session.createQuery...
this.getHibernateTemplate().execute(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException, SQLException { return session.createQuery(hql).executeUpdate();...
return (List) getHibernateTemplate().execute(new HibernateCallback(){ public Object doInHibernate(Session session) throws HibernateException{ List result = session.createCriteria(Address.class).add...
return (PageSupport) getHibernateTemplate().execute( new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException, SQLException { Criteria criteria = cq....
弃用了struts,用spring mvc框架做了几个项目,感觉都不错,而且使用了注解方式,可以省掉一大堆配置文件。本文主要介绍使用注解方式配置的spring mvc,之前写的spring3.0 mvc和rest小例子没有介绍到数据层的内容,...
return getHibernateTemplate().execute(new HibernateCallback<List<String>>() { @Override public List<String> doInHibernate(Session session) throws HibernateException, SQLException { Query query = ...
CtxUtil.getBaseManager().getHibernateTemplate().execute(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException, SQLException { // 保存stu1 Student stu1 = ...
return (List) getHibernateTemplate().execute(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException { Criteria criteria = session.createCriteria(Person....
return (Student) getHibernateTemplate().execute(new HibernateCallback() { @Override public Student doInHibernate(Session session) throws HibernateException { // ... 查询逻辑 ... } }); } } ``` ...
在`HibernateTemplate`中执行事务操作通常涉及到`execute`方法,该方法接受一个实现了`HibernateCallback`接口的匿名类实例作为参数。`HibernateCallback`的`doInHibernate`方法会在Hibernate的Session上下文中执行...
return getHibernateTemplate().execute(new HibernateCallback<List<User>>() { public List<User> doInHibernate(Session session) throws HibernateException, SQLException { Query query = session....
虽然`HibernateTemplate`提供了很多便利,但它在处理复杂查询时可能需要创建内部类(inner class),如在分页查询时使用`execute(HibernateCallBack)`,这可能会增加调试的复杂性。相比之下,直接使用`Session`进行...
HibernateCallback<List<Dept>> callback = new HibernateCallback<List<Dept>>() { @Override public List<Dept> doInHibernate(Session session) throws HibernateException, SQLException { Query query = ...
通常,程序中采用实现HibernateCallback的匿名内部类来获取HibernateCallback的实例,方法doInHibernate()就是Spring执行的持久化操作。 24.3 Spring对Hibernate的简化 24.3.5 HibernateDaoSupport Spring为与...
如示例所示,通过`getHibernateTemplate().execute()`方法传递一个`HibernateCallback`,然后在回调方法中创建并执行`CallableStatement`。这使得在Java应用程序中直接调用数据库的存储过程成为可能,提高性能并简化...
return getHibernateTemplate().executeFind(new HibernateCallback<List<Member>>() { public List<Member> doInHibernate(Session session) throws HibernateException, SQLException { Query query = session....
HibernateDaoSupport封装了HibernateTemplate,而HibernateTemplate封装了Hibernate所提供几乎所有的的数据操作方法,如execute(HibernateCallback action),load(Class entityClass, Serializable id),save(final ...
在`queryForPage`方法中,我们使用了`HibernateCallback`接口回调,通过`getHibernateTemplate().executeFind()`执行HQL查询并设置分页参数`setFirstResult`和`setMaxResults`。`getAllRowCount`方法则直接返回HQL...