Mysql基础(四)事务
2021/11/17 2:09:46
本文主要是介绍Mysql基础(四)事务,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
事务
- 隔离级别
- 事务的实现(MVCC多版本并发并发控制):
事务基于InnoDB引擎,MyISAM不支持事务,这也是Mysql5.6后将InnoDB作为默认数据库的原因之一
隔离级别
SQL 标准的事务隔离级别包括: 读未提交(read uncommitted)、读提交(read committed)、 可重复读(repeatable read)和串行化(serializable )。 读未提交是指,一个事务还没提交时,它做的变更就能被别的事务看到()。 读提交是指,一个事务提交之后,它做的变更才会被其他事务看到。 可重复读是指,一个事务执行过程中看到的数据,总是跟这个事务在启动时看到 的数据是一致的。当然在可重复读隔离级别下,未提交变更对其他事务也是不 可见的。 串行化,顾名思义是对于同一行记录,“写”会加“写锁”,“读”会加“读锁”。当出 现读写锁冲突的时候,后访问的事务必须等前一个事务执行完成,才能继续 执行。
事务的实现(MVCC多版本并发并发控制):
读提交和可重复读都是基于视图(read-view)实现的
读提交:每个SQL语句开始时创建一个视图 可重复读:事务开始时创建一个视图
数据库的MVCC:一条记录上可能存在多个版本(视图)
记录的每次更新都会记录一个回滚操作(图中箭头代表回滚,更新的逆运算),假使图中情况下,事务开始时创建的视图是read-view A,读取值时,并不是直接读到数值,而是通过从read-view C往前回滚。
- read-view C:当前值 —— 4,回滚操作 —— 4-1
- read-view B:当前值 —— 3,回滚操作 —— 3-1
- read-view A:当前值 —— 2,回滚操作 —— 2-1
参考:极客时间 Mysql45讲专栏 作者:林晓斌, 网名"丁奇",腾讯云数据库负责人
这篇关于Mysql基础(四)事务的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-01部署MySQL集群教程:新手入门指南
- 2024-11-01如何部署MySQL集群:新手入门教程
- 2024-11-01部署MySQL集群学习:新手入门教程
- 2024-11-01部署MySQL集群入门:新手必读指南
- 2024-10-23BinLog入门:新手必读的MySQL二进制日志指南
- 2024-10-23Binlog入门:MySQL数据库的日志管理指南
- 2024-10-22MySQL数据库入门教程:从安装到基本操作
- 2024-10-22MySQL读写分离入门教程:轻松实现数据库性能提升
- 2024-10-22MySQL分库分表入门教程
- 2024-10-22MySQL慢查询的诊断与优化指南