今天研究了一天的关于Spring,Hibernate,ResultSet和事务, 最后发现只有直接返回结果集的地方,事务管起来都是麻烦不断。 所以任何时候直接返回结果集都是一个坏主意。
如果想利用Hibernate直接执行Sql进行带事务的更新/删除操作,可以用下面的方法,当然方法在使用的过程中,需要根据自己的实际情况稍作改动。
如果想利用Hibernate返回一个结果集而且带着事务管理,至少我还没找到一个合理的解决方案。当然如果你说利用setAutoCommit(false), 然后自己手动控制,至少对Sybase这样不行。
如果想利用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这样不行。

本文探讨了在使用Spring和Hibernate框架时,直接返回ResultSet所引发的问题,并提供了一种利用Hibernate执行SQL进行带事务更新/删除操作的方法。同时指出,在事务管理中直接返回结果集不是一个好的实践。
1164

被折叠的 条评论
为什么被折叠?



