Spring中HibernateCallback()的用法

Hibernate的复杂用法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执行的持久化操作。

<span style="color:#444444;">package cn.itcast.elec.dao.impl;

import java.sql.SQLException;
import java.util.List;

import org.hibernate.Hibernate;
import org.hibernate.HibernateException;
import org.hibernate.Query;
import org.hibernate.Session;
import org.springframework.orm.hibernate3.HibernateCallback;
import org.springframework.stereotype.Repository;

import cn.itcast.elec.dao.IElecUserRoleDao;
import cn.itcast.elec.domain.ElecUserRole;

@Repository(IElecUserRoleDao.SERVICE_NAME)
public class ElecUserRoleDaoImpl extends CommonDaoImpl<ElecUserRole> implements
		IElecUserRoleDao {

	/**  
	* @Name: findElecUserListByRoleID
	* @Description: 查询用户列表集合,获取系统中所有的用户,并与该角色拥有的用户进行匹配
	* @Author: wjy(作者)
	* @Version: V1.00 (版本号)
	* @Create Date: 2015.01.14 (创建日期)
	* @Parameters: String roleID 角色ID
	* @Return: List<Object[]> 用户集合(匹配完成)
	*/
	@SuppressWarnings("unchecked")
	public List<Object[]> findElecUserListByRoleID(final String roleID) {
		final String sql = "select distinct case elec_user_role.RoleID " +
							"when ? then '1' else '0' end as flag, "+
							"elec_user.UserID as userID, "+
							"elec_user.UserName as userName, "+
							"elec_user.LogonName as logonName "+
							"from elec_user "+
							"left outer join elec_user_role " +
							"on elec_user.UserID = elec_user_role.UserID "+
							"and elec_user_role.roleID=? "+
							"where elec_user.IsDuty='1'";
		List<Object[]> list = (List<Object[]>)this.getHibernateTemplate().execute(new </span><span style="color:#cc0000;">HibernateCallback()</span><span style="color:#444444;"> {			
			@SuppressWarnings("deprecation")
			public Object </span><span style="color:#cc0000;">doInHibernate</span><span style="color:#444444;">(Session session) throws HibernateException,
					SQLException {
				Query query = session.createSQLQuery(sql)
						.addScalar("flag", Hibernate.STRING)
						.addScalar("userID", Hibernate.STRING)
						.addScalar("userName", Hibernate.STRING)
						.addScalar("logonName",Hibernate.STRING);
				query.setString(0, roleID);
				query.setString(1, roleID);
				return query.list();
			}
		});
		return list;
	}

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


你可能感兴趣的:(spring)