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>() {@Overridepublic Integer doInHibernate(Session session)throws HibernateException, SQLException {SQLQuery q = session.createSQLQuery(sql);return q.executeUpdate();}});return reValue;}