Spring,Hibernate,ResultSet和事务

今天研究了一天的关于Spring,Hibernate,ResultSet和事务, 最后发现只有直接返回结果集的地方,事务管起来都是麻烦不断。 所以任何时候直接返回结果集都是一个坏主意。
如果想利用Hibernate直接执行Sql进行带事务的更新/删除操作,可以用下面的方法,当然方法在使用的过程中,需要根据自己的实际情况稍作改动。
public int executeUpdate(Class<?> entityClass, final String sql) {
int reValue = 0;
HibernateTemplate hibernateTemplate = new HibernateTemplate(
getSessionFactory(entityClass));
reValue = hibernateTemplate.execute(new HibernateCallback<Integer>() {
@Override
public Integer doInHibernate(Session session)
throws HibernateException, SQLException {
SQLQuery q = session.createSQLQuery(sql);
return q.executeUpdate();
}
});

return reValue;
}


如果想利用Hibernate返回一个结果集而且带着事务管理,至少我还没找到一个合理的解决方案。当然如果你说利用setAutoCommit(false), 然后自己手动控制,至少对Sybase这样不行。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值