事务
1、什么事务(1)事务是数据库操作最基本单元,逻辑上一组操作,要么都成功,如果有一个失败所有操作都失败 2、事务四个特性(ACID)(1)原子性(2)一致性(3)隔离性(4)持久性 1.原子性:不可分割,要么成功都成功,失败都失败 2.一致性:比如每人 100,总数 200,转账之后,总数依然是 2003.隔离性:两个人操作同一条数据,互不干扰 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)设置出现哪些异常不进行事务回滚
版权声明: 本文为 InfoQ 作者【ssun】的原创文章。
原文链接:【http://xie.infoq.cn/article/f70bafd1c2c965b043a43b7a7】。文章转载请联系作者。
评论