2021
03-24
03-24
详解MySQL 数据库隔离级别与MVCC
Mysql是我们日常生产与学习中最常接触到的数据库之一,今天讲一讲在Mysql(或者说其他类似的数据库)中存在的隔离级别以及用来提高效率的多版本并发控制(MVCC)。一、隔离级别首先我们需要提到一个概念:事务。什么是事务?事务就是完成一个基础操作的一系列操作语句的一个集合。例如我要将200元从账户A转移到账户B,那么我可能会进行一下的操作:a.验证账户A中的余额是否大于200元。b.将账户A中的余额减200元。c.将账户B中的余额...
继续阅读 >
1.事务的特性(ACID)(1)原子性(Atomicity)。事务中所涉及的程序对数据库的修改操作要么全部成功,要么全部失败。(2)一致性(Consistency)。事务执行前和执行后来源和去向保持平衡。(3)隔离性(Isolation)。并发时每个事务是隔离的,相互不影响。(4)持久性(Durubility)。一旦事务成功提交,应该保证数据的完整存在。2.事务隔离级别(1)readuncommitted未提交读所有事务都可以看到没有提交事务的数据。(2)readc...
1、事务具有ACID特性原子性(atomicity):一个事务被事务不可分割的最小工作单元,要么全部提交,要么全部失败回滚。一致性(consistency):数据库总是从一致性状态到另一个一致性状态,它只包含成功事务提交的结果隔离型(isolation):事务所做的修改在最终提交一起,对其他事务是不可见的持久性(durability):一旦事务提交,则其所做的修改就会永久保存到数据库中。2、事务的隔离级别1)隔离级别的定义与问题RE...