- 1.什么是事务
- 2.在什么时候想到使用事务
- 3.通常使用JDBC访问数据库,还是mybatis访问数据库,怎么处理事务
- 4.3中事务的处理方法,有什么不足
- 5.怎么解决不足
- 6.处理事务,需要怎么做,做什么
- 7.总结spring的事务
讲mysql的时候,提出了事务。事务是指一组sql语句的集合,集合中有多条sql语句,可能是insert,update,select,delete,我们希望这些多个sql语句都能成功,或者都失败,这些sql语句的执行是一致的,作为一个整体执行。
2.在什么时候想到使用事务当我的操作,涉及得到多个表,或者是多个语句的insert,update,delete。需要保证这些语句都是成功才能完成我的功能,或者都失败,保证操作是符合要求的。
在java代码中写程序,控制事务,此时事务应该放在哪里呢?
service类的业务方法上,因为业务方法会调用多个dao方法,执行多个sql语句
jdbc访问数据库,处理事务 Connection conn; conn.commit(); conn.rollback();
mybatis访问数据库,处理事务,SqlSession.commit(); SqlSession.rollback();
hibernate访问数据库,处理事务,Session.commit(); Session.rollback();
1.不同的数据库访问技术,处理事务的对象,方法不同,需要了解不同数据库访问技术使用事务的原理
2.掌握多种数据库中事务的处理逻辑,什么时候提交事物,什么时候回滚事物
3.处理事务的多种方法。
总结:就是多种数据库的访问技术,有不同的事物处理的机制,对象,方法。
spring提供一种处理事务的统一模型,能使用统一步骤,方式完成多种不同数据库访问技术的事务处理。
使用spring的事务处理机制,可以完成mybatis访问数据库的事物处理
使用spring的事务处理机制,可以完成hibernate访问数据库的事务处理。
spring处理事务的模型,使用的步骤都是固定的。把事务使用的信息提供给spring就可以了
-
1.事务内部提交,回滚事物,使用的事务管理器对象,代替你完成了commit,rollback
事务管理器是一个接口和他的众多实现类。
接口:PlatformTransactionManager,定义了事务重要方法commit,rollback
实现类:spring把每一种数据库访问技术对应的事务处理类都创建好了。
mybatis访问数据库—spring创建好的是DataSourceTransactionManager
hibernate访问数据库—spring创建好的是HibernateTransactionManager
怎么使用:你需要告诉spring你用的是哪种数据库的访问技术,怎么告诉spring呢?
声明数据库访问技术对应的事务管理器实现类,在spring的配置文件中使用声明就可以了
-
2.你的业务方法需要什么样的事务,说明需要事务的类型。
说明方法需要的事务:
1)事务的隔离级别:有4个值.
DEFAULT:采用DB默认的事务隔离级别。MySql的默认为Repeatable_read;Oracle默认为Read_uncommitted。
第一种隔离级别:Read uncommitted(读未提交),未解决任何并发问题。
第二种隔离级别:Read committed(读已提交),解决读脏,存在不可重复读与幻读。
第三种隔离级别:Repeatable read(可重复读取),解决读脏,不可重复读,存在幻读。
第四种隔离级别:Serializable(可序化)串行化,不存在并发问题。
2)事务的超时时间:表示一个方法最长的执行时间,如果方法执行超过了时间,事务就回滚。单位是秒,整数值,默认是-1。
3)事务的传播行为:控制业务方法是不是有事务的,是什么样的事务的。
7个传播行为,表示你的业务方法调用时,事务在方法之间是如何使用的。
前三个需要掌握。
| 事务行为 | 说明 |
|---|---|
| PROPAGATION_REQUIRED | 支持当前事务,假设当前没有事务。就新建一个事务 |
| PROPAGATION_REQUIRES_NEW | 新建事务,假设当前存在事务。把当前事务挂起 |
| PROPAGATION_SUPPORTS | 支持当前事务,假设当前没有事务,就以非事务方式运行 |
| PROPAGATION_MANDATORY | 支持当前事务,假设当前没有事务,就抛出异常 |
| PROPAGATION_NOT_SUPPORTED | 以非事务方式运行操作。假设当前存在事务,就把当前事务挂起 |
| PROPAGATION_NEVER | 以非事务方式运行,假设当前存在事务,则抛出异常 |
| PROPAGATION_NESTED | 如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行与PROPAGATION_REQUIRED类似的操作。 |
- 3.事务提交事物,回滚事务的时机
1)当你的业务方法,执行成功,没有异常抛出,当方法执行完毕,spring在方法执行后提交事物。事务管理器commit。
2)当你的业务方法抛出运行时异常,spring执行回滚,调用事务管理器的rollback
运行时异常定义:RuntimeException 和他的子类都是运行时异常,例如NullPointException,NumberFormatException.
3)当你的业务方法抛出非运行时异常,主要是受查异常时,提交事务。
受查异常:在你写代码中,必须处理的异常。例如IOException,SQLException
- 1.管理事务的是 事务管理器和他的实现类
- 2.spring的事务是一个统一模型
1)指定要使用的事务管理器的实现类,使用
2)指定哪些类,哪些方法需要加入事务的功能
3)指定方法需要的隔离级别,传播行为,超时
你需要告诉spring,你的项目中类信息,方法的名称,方法的事务传播行为。



