1、什么事务
(1)事务是数据库操作最基本单元,逻辑上一组操作,要么都成功,如果有一个失败所有操作都失败
2、事务四个特性(ACID)
(1)原子性
(2)一致性
(3)隔离性
(4)持久性
1.原子性:不可分割,要么成功都成功,失败都失败
2.一致性:比如每人100,总数200,转账之后,总数依然是200
3.隔离性:两个人操作同一条数据,互不干扰
4.持久性:事务提交之后,表中数据修改,修改的内容不变
举例:实现jack少100,lucy多100
1、创建数据库表,添加记录
xml配置
2、创建service,搭建dao,完成对象创建和注入关系
(1) service注入dao,在dao注入JdbcTemplate,在JdbcTemplate 注入DataSource
3、在 dao,创建两个方法:多钱和少钱的方法,在service创建方法(转账的方法)
4、上面代码,如果正常执行没有问题的,但是如果代码执行过程中出现异常,有问题,这时候要做出事务处理
事务操作:
1、事务添加到JavaEE三层结构里面Service层(业务逻辑层)
2、在Spring进行事务管理操作
(1)有两种方式:编程式事务管理和声明式事务管理(使用)
3、声明式事务管理
(1)基于注解方式(使用)
(2)基于xml配置文件方式
4、在Spring进行声明式事务管理,底层使用AOP原理
5、Spring事务管理API
(1)提供一个接口,代表事务管理器,这个接口针对不同的框架提供不同的实现类
spring框架的JdbcTemplate和mybatis用DataSourceTransactionManager
具体操作
1、在spring配置文件配置事务管理器
2、在spring配置文件,开启事务注解
(1)在spring配置文件引入名称空间tx
(2) 开启事务注解
要使用全注解开发(配置类)
3、在service类上面(或者service类里面方法上面)添加事务注解(1)@Transactional,这个注解添加到类上面,也可以添加方法上面
(2)如果把这个注解添加类上面,这个类里面所有的方法都添加事务
(3)如果把这个注解添加方法上面,为这个方法添加事务
(4) 一些常见的参数
-
1、propagation:事务传播行为
(1)多事务方法直接进行调用,这个过程中事务是如何进行管理的
事务方法:对表修改了数据,比如增删修改,查询不算 -
2、ioslation:事务隔离级别
(1)事务有特性成为隔离性,多事务操作之间不会产生影响。不考虑隔离性产生很多问题。
(2)有三个读问题:脏读、不可重复读、虚(幻)读
脏读:一个未提交事务读取到另一个未提交事务的数据(事务回滚)
不可重复读:一个未提交事务读取到另一提交事务修改数据(提交事务)
虚读:一个未提交事务读取到另一提交事务添加数据
mysql默认可重复读 -
3、timeout:超时时间
(1)事务需要在一定时间内进行提交,如果不提交进行回滚
(2)默认值是-1,设置时间以秒单位进行计算 -
4、readOnly:是否只读
(1)读:查询操作,写:添加修改删除操作。
(2) readOnly默认值false,表示可以查询,可以添加修改删除操作
(3)设置readOnly值是true,设置成true之后,只能查询。 -
5、rollbackFor:回滚
(1)设置出现哪些异常进行事务回滚 -
6、noRollbackFor:不回滚
(1)设置出现哪些异常不进行事务回滚