HibernateCallback接口



	public List<Object> querySQL(final String hql,final Class entityClass)
	{
		try{			
			return this.getHibernateTemplate().execute(new HibernateCallback<List<Object>>() {
				@Override
				public List<Object> doInHibernate(Session session)throws HibernateException, SQLException 
				{
					Query query=session.createSQLQuery(hql).addEntity(entityClass);
					return query.list();
				}
			});		
		}catch(RuntimeException re) {
			throw re;
		}
	}


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的灵活访问方式是通过如下两个方法完成:

(1)Object execute(HibernateCallback action)

(2)List execute(HibernateCallback action) 这两个方法都需要一个HibernateCallback的实例,HibernateCallback实例可在任何有效的Hibernate数据访问中使用。 程序开发者通过HibernateCallback,可以完全使用Hibernate灵活的方式来访问数据库,解决Spring封装Hibernate后灵活性不足的缺陷。


HibernateCallback是一个接口,该接口只有一个方法doInHibernate(org.hibernate.Session session), 该方法只有一个参数Session。通常,程序中采用实现HibernateCallback的匿名内部类来获取HibernateCallback的实例, 方法doInHibernate的方法体就是Spring执行的持久化操作。 还有的就是采用: HibernateTemplate.execute(HibernateCallback action)这种回调的方式,封装了对异常的处理和对事务的一些处理。



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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值