今天研究了一天的关于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这样不行。