前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >spring支持的数据库事务传播行为和事务隔离级别

spring支持的数据库事务传播行为和事务隔离级别

作者头像
名字是乱打的
发布2022-05-13 12:49:04
4310
发布2022-05-13 12:49:04
举报
文章被收录于专栏:软件工程
一 spring支持的事务的传播行为种类(共七种,最常用的是前两种)

image.png

例子

image.png

二 图解REQUIRES,REQUIRES_NEW

REQUIRES图解---默认在原事务中执行,必须两次操作都没问题才可以不会滚直接提交

image.png

REQUIRES_NEW图解---将原事务挂起不用,开启自己的事务进行执行,各个子操作自行进行事务分析有误回滚,原事务不再涉及回滚问题

image.png

三 事务的行为如何定义?
代码语言:javascript
复制
如果方法A()需要开启事务,则需要加@Transactional注解
eg  :
@Transactional
public void A(){
}
若要定义事务的传播行为则需要对注解加上属性
如定义将方法A的事务传播行为定义为REQUIRES_NEW,则如下:
@Transactional(Propagation=Propagation.REQUIRES_NEW)
public void A(){
}
数据库事务的并发问题

假设现在有两个事务:Transaction01和Transaction02并发执行。 1]脏读。 ①Transaction01将某条记录的AGE值从20修改为30。 ②Transaction02读取了Transaction01更新后的值:30。 ③Transaction01回滚,AGE值恢复到了20。 ④Transaction02读取到的30就是一个无效的值。

2)不可重复读 ①Transaction01 读取了AGE值为20。 ②Transaction02将AGE值修改为30。 ③Transaction01 再次读取AGE值为30,和第一次读取不一致。

3)幻读 ①Transaction01 读取了STUDENT表中的一部分数据。 ②Transaction02向STUDENT表中插入了新的行。 ③Transaction01读取了STUDENT表时,多出了一些行。

事务的隔离级别

数据库对事务并发问题的避免 数据库系统必须具有隔离并发运行各个事务的能力,使它们不会相互影响,避免各种并发问题。一个事务与其他事务隔离的程度称为隔离级别。SQL标准中规定了多种事务隔离级别,不同隔离级别对应不同的干扰程度,隔离级别越高,数据一致性就越好,但并发性越弱。 四个隔离级别(oracle默认可重复读 mysql默认读已提交)

代码语言:javascript
复制
1)读未提交:READ UNCOMMITTED允许Transaction01读取Transaction02未提交的修改。
2)读已提交:READ COMMITTED要求Transaction01只能读取Transaction02已提交的修改。
3)可重复读:REPEATABLE READ
确保Transaction01可以多次从一个字段中读取到相同的值,即Transaction01执行期间禁止其它事务
对这个字段进行更新。
4)串行化:SERIALIZABLE+
确保Transaction01可以多次从一个表中读取到相同的行,在Transaction01执行期间,禁止其
它事务对这个表进行添加、更新、删除操作。可以避免任何并发问题,但性能十分低下。
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-05-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一 spring支持的事务的传播行为种类(共七种,最常用的是前两种)
  • 二 图解REQUIRES,REQUIRES_NEW
  • 三 事务的行为如何定义?
  • 数据库事务的并发问题
  • 事务的隔离级别
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档