数据库事物处理

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只允许有一个未提交的事务,不能同时开始两个事务
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值