学习MySql并发事务以及解决方法笔记

事务是数据库操作的基本单位,遵循ACID原则,包括原子性、一致性、隔离性和持久性。事务隔离级别包括读未提交、读已提交、可重复读和串行化,用于解决并发问题如脏读、不可重复读和幻读。默认情况下,MySQL事务是自动提交的,建议设置为手动提交以提高数据安全性。
摘要由CSDN通过智能技术生成

事务是一系列的数据库操作,他们符合ACID四大特征,事务是数据库应用的基本单位

A:原子性---事务中的操作要么全部成功,要么全部失败。如果失败则进行事务的回滚,设计到回滚日志undo log

C:一致性---数据库总是从一个一致性的状态转移到另一个一致性的状态,无中间状态

I:隔离性---一个事务在完全提交前,对其他事务是不可见的。但也有特殊情况

D:持久性---事务一旦提交,对数据库的更改是永久的。

事务过程:启动事务,数据库操作,提交事务(回滚事务)

注:mysql中的事务操作默认自动提交,最好更改为手动提交

下图mysql中的四种事务隔离级别以及默认隔离等级:

事务的隔离等级用来解决并发事务所带来的问题:脏读,不可重复读,幻读

同时,事务的隔离等级越高,数据就更加安全,性能就差

脏读:一个事务读取到了另一个事务未提交的数据。

事务A对表中张三的人工资加上1000(A事务未提交,隔离级别:read uncommitted),事务B对同一张表中张三的工资进行查询,查询到的是事务A未提交的事务。

不可重复读:一个事务执行两次相同的操作,查找到的结果不同。

----针对于更新操作

事务A先查询工资表,事务B对张三的工资加上1000(事务提交,隔离级别:read commited),事务A再次执行相同的语句,张三的工资发生变化。

幻读

----针对于增删操作

事务A想对工资表中添加李四的信息,事务B想工资表中插入李四的信息(A事务执行插入之前,B事务操作完成后事务提交)。当事务A插入李四的信息时会显示数据已插入,但是查询工资表又看不到信息(当前隔离级别为默认隔离级别,不会出现不可重复读的现象),在事务A看来就好像凭空出现了一条数据,出现幻象。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值