聊一聊Spring统一处理事务 并代码演示案例(整合Mybatis)

一、基本概念

1、什么是事务
讲mysql的时候,提出了事务。事务是指一组sql 语句的集合,集合中有多条sql语句,可能是insert ,update,select ,delete,我们希望这些多个sql语句都能成功,或者都失败,这些sql 语句的执行是一致的,作为一个整体执行。

2、在什么时候想到使用事务
当我的操作,涉及得到多个表,或者是多个sql语句的insert,update,delete 需要保证这些语句都是成功才能完成我的功能,或者都失败,保证操作是符合要求的。
在java代码中写程序,控制事务,此时事务应该放在那里呢?
service类的业务方法上,因为业务方法会调用多个dao方法,执行多个sql语句。

3、通常使用JDBC访问数据库,还是mybatis访问数据库?怎么处理事务
jdbc访问数据库,处理事务Connection conn ;conn. commit() ;conn.rollback() ;
mybatis访问数据库,处理事务,sqlSession. commit();sqlSession. rollback() ;
hibernate访问数据库,处理事务,Session.commit(); Session. rollback() 。

4、在3问题中事务的处理方式,有什么不足
1)不同的数据库访问技术,处理事务的对象,方法不同,需要了解不同数据库访问技术使用事务的原理
2)掌握多种数据库中事务的处理逻辑。什么时候提交事务,什么时候回顾事务
3)处理事务的多种方法。

总结:就是多种数据库的访问技术,有不同的事务处理的机制,对象,方法。

5、怎么解决不足
spring提供一种处理事务的统一模型,能使用统一步骤,方式完成多种不同数据库访问技术的事务处理。
使用spring的事务处理机制,可以完成mybatis访问数据库的事务处理
使用spring的事务处理机制,可以完成hibernate访问数据库的事务处理。
在这里插入图片描述
6、处理事务,需要怎么做,做什么
spring处理事务的模型,使用的步骤都是固定的。把事务使用的信息提供给spring就可以了

1)事务内部提交,回滚事务,使用的事务管理器对象,代替你完成commit, rollback
事务管理器是一个接口和他的众多实现类
接口:PlatformTransactionManager ,定义了事务重要方法commit ,rollback
实现类:spring把每一种数据库访问技术对应的事务处理类都创建好了。

mybatis访问数据库:spring创建好的是DataSourceTransactionManager
hibernate访问数据库:spring创建的是HibernateTransactionManager

怎么使用:你需要告诉spring你用是那种数据库的访问技术,怎么告诉spring呢?
声明数据库访问技术对于的事务管理器实现类,在spring的配置文件中使用bean标签声明就可以了

例如,你要使用mybatis访问数据库,你应该在xml配置文件中这样配置:
在这里插入图片描述
2)你的业务方法需要什么样的事务,说明需要事务的类型.

事务的隔离级别:有4个值。
DEFAULT:采用DB默认的事务隔离级别。MySql的默认为REPEATABLE READ, Oracle默认为READ_ COMMITTED 。
READ_ UNCOMMITTED:读未提交。未解决任何并发问题
READ COMMITTED: 读已提交。解决脏读,存在不可重复读与幻读(Oracle默认)
REPEATABLE READ:可重复读。解决脏读、不可重复读,存在幻读(Mysql默认)
SERIALIZABLE: 串行化。不存在并发问题

事务的超时时间:表示一个方法最长的执行时间,如果方法执行时超过了时间,事务就回滚。单位是秒,整数值, 默认是 -1。

③)事务的传播行为:控制业务方法是不是有事务的,是什么样的事务的。
7个传播行为,表示你的业务方法调用时,事务在方法之间是如何使用的。

PROPAGATION REQUIRED
不管A是否有事务,只要调用B,那么B都是在事务中。(A有事务B就使用A的事务,没有则会创建一个新的事务)
PROPAGATION REQUIRES NEW
不管A有无事务,B都是会创建一个新的事务(A有事务时就会先挂起A的事务,等待B事务执行完毕)
PROPAGATION SUPPORTS
这个是有无事务都是可以的,比如说查询**
以上三个需要掌握的

PROPAGATION MANDATORY
PROPAGATION NESTED
PROPAGATION NEVER
PROPAGATION NOT SUPPORTED

3)事务提交事务,回滚事务的时机

①当你的业务方法执行成功,没有异常抛出,当方法执行完毕,spring在方法执行后提交事务。事务管理器commit

②当你的业务方法抛出运行时异常,spring执行回滚, 调用事务管理器的rollback,运行时异常的定义:RuntimeException和他的子类都是运行时异常,例如Nul1PointException,NurberFormatException.

③ 当你的业务方法抛出非运行时异常, 主要是受查异常时,提交事务
受查异常:在你写代码中,必须处理的异常。例如IOException, SQLException

总结spring的事务
1.管理事务的是事务管理器和它的实现类

2. spring的事务是一个统一模型

1)指定要使用的事务管理器实现类,使用bean标签
2)指定哪些类,哪些方法需要加入事务的功能
3)指定方法需要的隔离级别,超时,传播行为

这里有详细说明:聊一聊Spring中@Transactional注解及其失效的六种场景

二、程序举例

举例:购买商品trans_ sale 项目
本例要实现购买商品,模拟用户下订单,向订单表添加销售记录,从商品表减少库存。

前期准备

1、创建数据库表,创建两个数据库表sale , goods

sale销售表
在这里插入图片描述
goods商品表
在这里插入图片描述
2、创建Maven项目,引入依赖

(1)创建Maven项目(我没有选择骨架 ,你随意,可以选择webapp)
在这里插入图片描述
配置好目录(要是目录自动生成就不用了):
在这里插入图片描述
在这里插入图片描述

(2)pom.xml引入依赖(直接粘贴我的依赖即可几乎包含了spring的全部常用的依赖)
在这里插入图片描述
为了使篇幅更小我就全部折叠了,你粘贴进去,再同时按住 Ctrl + Alt + L 格式化代码即可

<dependencies><dependency> <groupId>junit</groupId> <artifactId>junit</artifactId><version>4.12</version> <scope>test</scope></dependency><!--spring-test(对JUnit的封装)--> <dependency> <groupId>org.springframework</groupId><artifactId>spring-test</artifactId>
<version>5.2.8.RELEASE</version><scope>test</scope></dependency
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值