`

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这样不行。
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics