概述
一、什么是事务?
Transaction
- 事务:事务是逻辑上的一组操作,要么都执行,要么都不执行。是一个最小的不可再分的工作单元;通常一个事务对应一个完整的业务(例如银行账户转账业务,该业务就是一个最小的工作单元)
- 一个完整的业务需要批量的DML语句(insert、update、delete)共同联合完成
- 事务只和DML语句有关,或者说DML语句才有事务。这个和业务逻辑有关,业务逻辑不同,DML语句的个数不同
二、事务的一些术语
•开启事务:Start Transaction
•提交事务:Commit Transaction
•回滚事务:Rollback Transaction
•事务结束:End Transaction
三、和事务相关的两条重要的SQL语句(TCL 事务控制语言)
•commit: 提交
•rollback: 回滚
四、MySQL事务的4大特性/4个基本要素(ACID)
- 原子性(Atomicity):事务开始后,所有操作要么全部提交成功,要么全部失败并且回滚操事务开始前的状态,所有的操作就像没有发生一样,不可能一部分提交成功一部分提交失败。也就是说事务是一个不可分割的整体,就像化学中学过的原子,是物质构成的基本单位。
- 一致性(Consistency):事务开始前和结束后,数据库的完整性约束没有被破坏 ,数据库仍然是一个完整性状态。比如A向B转账,不可能A扣了钱,B却没收到。
- 隔离性(Isolation):多个用户同一时间并发访问数据库时,只允许一个事务请求同一数据,其他事物不可操作这一数据,不同的事务之间相互隔离。比如A正在从一张银行卡中取钱,在A取钱的过程结束前,B不能向这张卡转账。
- 持久性(Durability):事务完成后,事务对数据库的所有操作将被保存到数据库也就是保存到计算机硬盘里面,不能回滚。
五、MySQL事务的并发问题
- 脏读:事务A读取了事务B更新的数据,然后B回滚操作,那么A读取到的数据是脏数据
- 不可重复读:事务 A 多次读取同一数据,事务B 在事务A多次读取的过程中,对数据作了更新并提交,导致事务A多次读取同一数据时,结果 不一致。
- 幻读:系统管理员A将数据库中所有学生的成绩从具体分数改为ABCDE等级,但是系统管理员B就在这个时候插入了一条具体分数的记录,当系统管理员A改结束后发现还有一条记录没有改过来,就好像发生了幻觉一样,这就叫幻读。
小结:不可重复读的和幻读很容易混淆,
不可重复读侧重于修改,幻读侧重于新增或删除。
解决不可重复读的问题只需锁住满足条件的行,解决幻读需要锁表。
六、MySQL事务(4种)隔离级别
事物四大特性之一隔离性的隔离级别一共有四种:
未提交读(read-uncommitted)、已提交读(read-committed)、
可重复读(repeatable-read)、可串行读(serializable)
事务隔离级别 | 脏读 | 不可重复读 | 幻读 |
---|---|---|---|
未提交读(read-uncommitted) | 是 | 是 | 是 |
已提交读(read-committed) | 否 | 是 | 是 |
可重复读(repeatable-read) (默认隔离级别) | 否 | 否 | 是 |
可串行读(serializable) | 否 | 否 | 否 |
未提交读:在该级别事务中的修改,即使没有提交,对其他事务也都是可见的。事务可以读取未提交的数据,这也称为赃读。(即便是事务没有commit,但是我们仍然能读到未提交的数据,这是所有隔离级别中最低的一种)
已提交读:当前会话只能读取到其他事务已提交的数据,未提交的数据读不到。
备注:最后鸣谢如下
学习链接:https://www.cnblogs.com/huanongying/p/7021555.html
最后
以上就是含蓄小蘑菇为你收集整理的mysql数据库事物,以及事物中的脏读、不可重复读、幻读、4种隔离级别!的全部内容,希望文章能够帮你解决mysql数据库事物,以及事物中的脏读、不可重复读、幻读、4种隔离级别!所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复