7.1 事务
什么是事务
事务是指一组sql语句的集合, 集合中有多条sql语句,这些sql语句是一个整体,要么全部执行,要么都不执行。
何时用事务
当操作涉及得到多个表,或者是多个sql语句的增删改查,并且要求执行有一致性时用事务,如银行实现转账功能,我们会希望转账成功后,一方扣除了金额,一方增加相应金额;当操作过程出现异常时,整个操作会进行回滚,两方的账户情况恢复到初始状态,而不是一人扣钱一人未收到钱。
什么地方用到事务
service类的业务方法上,因为业务方法会调用多个dao方法,执行多个sql语句
处理事务的对象的方法
-
JDBC:
Connection conn
,conn.commit()
,conn.rollback()
-
MyBatis:
SqlSession.commit()
,SqlSession.rollback()
-
Hibernate:
Session.commit()
,Session.rollback()
不足:即不同的数据库访问技术处理事务的对象,方法不同,因此需要了解不同数据库访问技术使用事务的原理;还要掌握多种数据库中事务的处理逻辑。什么时候提交事务,什么时候回顾事务,处理事务的多种方法
如何处理以上不足
spring提供一种处理事务的统一模型,能使用统一步骤,方式完成多种不同数据库访问技术的事务处理;如使用spring的事务处理机制,可以完成mybatis访问数据库的事务处理,也可以完成hibernate访问数据库的事务处理
处理事务需要做什么
spring处理事务的模型,使用的步骤都是固定的,把事务使用的信息提供给spring就可以了
-
事务内部提交,回滚事务,使用的事务管理器对象,代替你完成
commit
,rollback
。事务管理器是一个接口和他的众多实现类接口:
PlatformTransactionManager
,定义了事务重要方法commit
,rollback
实现类:spring把每一种数据库访问技术对应的事务处理类都创建好了
mybatis访问数据库—spring创建好的是DataSourceTransactionManager
hibernate访问数据库----spring创建的是HibernateTransactionManager
怎么使用
spring的配置文件中声明数据库访问技术的事务管理器实现类来告诉spring用例什么数据库的访问技术;如用mybatis访问数据库:<bean id=“xxx" class="...DataSourceTransactionManager">
- 你的业务方法需要什么样的事务,说明需要事务的类型
-
事务的隔离级别(有4个值)
DEFAULT
:采用 DB 默认的事务隔离级别。MySql 的默认为 REPEATABLE_READ; Oracle默认为 READ_COMMITTEDREAD_UNCOMMITTED
:读未提交。未解决任何并发问题READ_COMMITTED
:读已提交。解决脏读,存在不可重复读与幻读REPEATABLE_READ
:可重复读。解决脏读、不可重复读,存在幻读SERIALIZABLE
:串行化。不存在并发问题
-
事务的超时时间
表示一个方法最长的执行时间,如果方法执行时超过了时间,事务就回滚
单位是秒, 整数值, 默认是 -1 -
事务的传播行为
控制业务方法是不是有事务的, 是什么样的事务的(前三个常用)PROPAGATION_REQUIRED
:指定的方法必须在事务内执行。若当前存在事务,就加入到当前事务中;若当前没有事
务,则创建一个新事务。这种传播行为是最常见的选择,也是 Spring 默认的事务传播行为PROPAGATION_REQUIRES_NEW
:总是新建一个事务,若当前存在事务,就将当前事务挂起,直到新事务执行完毕PROPAGATION_SUPPORTS
:指定的方法支持当前事务,但若当前没有事务,也可以以非事务方式执行PROPAGATION_MANDATORY
PROPAGATION_NESTED
PROPAGATION_NEVER
PROPAGATION_NOT_SUPPORTED
-
事务提交事务,回滚事务的时机
- 当业务方法没有异常抛出,执行成功,spring在方法执行后提交事务。事务管理器commit
- 当业务方法抛出运行时异常或
ERROR
,spring执行回滚,调用事务管理器的rollback
运行时异常的定义:RuntimeException
和他的子类都是运行时异常,例如NullPointException
,NumberFormatException
- 当业务方法抛出非运行时异常, 主要是受查异常时,提交事务
受查异常:在你写代码中,必须处理的异常。例如IOException
,SQLException
-
总结spring的事务
- 管理事务的是 事务管理和他的实现类
- spring的事务是一个统一模型
- 指定要使用的事务管理器实现类,使用
- 指定哪些类,哪些方法需要加入事务的功能
- 指定方法需要的隔离级别,传播行为,超时