MYSQL事务隔离级别的实现原理

一 : 事务隔离级别

       在MySQL的众多存储引擎中,只有InnoDB支持事务,以下是InnoDB下的事务隔离级别

    1. 读未提交(Read Uncommitted)

        原理:任何操作都不加锁

    2. 读提交(Read Commit): MySQL默认

原理:读操作不加锁,写操作加锁。读被加锁的数据时,读事务每次都读undo log中的最近版本,因此可能对同一数据读到不同的版本(不可重复读),但能保证每次都读到最新的数据。
    3. 可重复读(Reapable Read): oracle默认

    原理:第一次读数据的时候就将数据加行锁(共享锁),使其他事务不能修改当前数据,即可实现可重复读。但是不能锁住insert进来的新的数据,当前事务读取或者修改的同时,另一个事务还是可以insert提交,造成幻读。
    4. 串行化(Serializable)

    原理:锁表,读锁和写锁阻塞。

二 : InnoDB事务相关概念

   1 . redo log

    MySQL在开启事务时,会将执行的SQL保存到指定的log文件,即redo log。当MySQL执行recovery时执行redo log里的SQL操作即可。redo log不会被立即写入磁盘,会先写入redo buffer;当客户端执行commit时,redo buffer的内容会视情况存入磁盘。

  2 . undo log

    与redo log相反,undo log是为了回滚事务而写的日志,具体内容就是copy事务开始前的数据(行)到undo buffer。

    与redo buffer一样,undo buffer也是环形缓冲,当缓冲满的时候buffer内容会被刷新到磁盘。

    与redo log不同的是,undo log没有独立的磁盘文件,所有的undo log均被存在主ibd数据文件中(表空间)。

三 : 快照读 , 当前读 , 一致性锁定读

   1 . 快照读:读取的是快照版本,也就是历史版本 . select

   2 . 当前读:读取的是最新版本 .   update , delete , insert , select ... lock in share mode , select ... for update

   3 . 锁定读

         select ... lock in share mode : 给记录假设共享锁,其它事务只能读不能修改,直到当前事务提交

         select ... for update : 给索引记录加锁,这种情况下跟UPDATE的加锁情况是一样的

 

 

你可能感兴趣的:(MySql)