数据库事物处理
Hibernate SessionFactory中openSession和getCurrentSession方法的区别:
1. 前者打开一个新的,后者当前有session的话,则是使用当前的session,没有的话则创建一个新的;
2. 如果使用前者获得一个session的话,需要手动关闭session,使用后者,当事务提交,session会自动关闭,如果再关闭session则会报如下异常:Session has already closed;
事务边界声明
只要声明了一个事务,数据库系统就会自动保证事务的ACID特性。
声明事务包含:
事务的开始边界
事务的正常结束边界(commit):提交事务,永久保存
事务的异常结束边界(rollback):撤销事务,数据库回退到执行事务前的状态
数据库支持两种事务模式:
自动提交模式:每个SQL语句都是一个独立的事务,数据库执行完一条SQL语句后,会自动提交事务。
手工提交模式:必须由数据库的客户程序显式指定事务的开始和结束边界
JDBC Connection类的事务控制方法:
setAutoCommit(boolean autoCommit) 设置是否自动提交事务,默认自动
commit() 提交事务
rollback() 撤销事务
Hibernate控制事务的方法:
1. 调用sessionFactory不带参数的openSession方法,从连接池获得连接,Session自动把连接设为手工提交事务模式。
Session session = sessionFactory.openSession();
若调用带connection参数的openSession,则需要自己设置手工提交:
connection.setAutoCommit(false);
Session session = sessionFactory.openSession(connection);
2. 声明事务的开始边界
Transaction tx = session.beginTransaction();
3. 提交事务
tx.commit();
4. 撤销事务:
tx.rollback();
一个session可以对应多个事务,但是应优先考虑让一个session只对应一个事务,当一个事务结束或撤销后,就关闭session.
不管事务成功与否,最后都应调用session的close关闭session
任何时候一个session只允许有一个未提交的事务,不能同时开始两个事务