写点什么

事务

作者:ssun
  • 2022-11-29
    四川
  • 本文字数:1172 字

    阅读完需:约 4 分钟

事务

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)设置出现哪些异常不进行事务回滚






发布于: 刚刚阅读数: 4
用户头像

ssun

关注

还未添加个人签名 2022-10-12 加入

还未添加个人简介

评论

发布
暂无评论
事务_事务_ssun_InfoQ写作社区