百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Mysql事务隔离级别RR与RC

wptr33 2025-01-20 17:03 13 浏览

在Mysql中,事务隔离级别RC(read commit)和 RR(repeatable read)两种事务隔离级别基于多版本并发控制MVCC(multi-version concurrency control)来实现。

由于RC隔离级别需要保持语句级别的一致性,事务中每一次读取都是访问当前时间点的已提交数据,因此事务中多查询语句时会创建多个不同的ReadView,开销较大,复杂度更高,而对于RR隔离级别,仅需要一个版本的ReadView,消耗更少。因此Mysql默认使用RR隔离级别。

    • RC隔离级别获得的语句级读一致性
    • RR隔离级别获得的事务级读一致性

if the transcation isolation level is REPEATABLE READ (the defalut level),all consistent reads within the same transcation read the snapshot established by the first such read in the transaction.

With READ COMMITTED isolation level,each consistent read within a transaction sets and reads its own fresh snapshot.

对于RC隔离级别,访问数据库是每次语句执行时间点的数据,而对于RR隔离级别,访问的数据是事务第一条语句执行时间点的数据。

在RR隔离级别下,执行start transaction命令后,并未开启事务,而是等到第一条语句执行时开启事务,并建立一致性读的snapshot,如果希望在start transaction时就建立一致性读的snapshot,可以使用START TRANSACTION WITH consistent snapshot。


对于RC隔离级别,不需要解决幻读的问题,当前读操作只对扫描到的数据进行加锁(行锁),无需使用GAP锁。

对于RR隔离级别,需要防止幻读的问题,当前读操作除对扫描到的数据进行加锁外,还需要使用GAP所有来防止数据插入到新记录。


GAP锁:在索引记录之间的间隙中加锁,或者是在某一条索引记录之前或者之后加锁,并不包括该索引记录本身。gap lock的机制主要是解决可重复读模式下的幻读问题。

幻读:指的是在一个事务A中执行了一个当前读操作,而另外一个事务B在事务A的影响区间内insert了一条记录,这时事务A再执行一个当前读操作时,出现了幻行。这和不可重复读的主要区别就在与事务A中一个是快照读,一个当前读;并且事务B中一个是任何的dml操作,一个只是insert。

--------------------------------------------------------------------------

查看当前事务级别:

SELECT @@tx_isolation;

设置当前事务级别

set session transaction isolation level read commintted;

set session transaction isolation level repeatable read;


四种事务级别区分:


相关推荐

史上最强vue总结,面试开发全靠它了

vue框架篇vue的优点轻量级框架:只关注视图层,是一个构建数据的视图集合,大小只有几十kb;简单易学:国人开发,中文文档,不存在语言障碍,易于理解和学习;双向数据绑定:保留了angular的特点,...

Node.js Stream - 实战篇(node.js 10实战)

本文转自“美团点评技术团队”http://tech.meituan.com/stream-in-action.html背景前面两篇(基础篇和进阶篇)主要介绍流的基本用法和原理,本篇从应用的角度,介...

JavaScript 中的 4 种新方法指南Array.

JavaScript中的4种新方法指南Array.prototypeArray其实和Python中的l列表list的操作用非常像JavaScript语言标准的最新版本是ECMAScript...

Js基础31:内置对象(js 内置对象)

js里面的对象分成三大类:内置对象ArrayDateMath...

常见vue面试题,大厂小厂都一样(vue经典面试题)

一、谈谈你对MVVM的理解?...

最全的 Vue 面试题+详解答案(vue面试题2020例子以及答案)

前言本文整理了...

不产生新的数组,删除数组里的重复元素

数组去重的方式有很多,我们可以使用Set去重、filter过滤等,详见携程&蘑菇街&bilibili:手写数组去重、扁平化函数...

更简单的Vue3中后台动态路由 + 侧边栏渲染方案

时至今日,vue2已经升级到了vue3,动态路由的实现方案也同步做出了一些升级迭代,帮助开发者们更高效的完成业务需求,然后摸鱼。本次逻辑的升级,主要聚焦于2点更加简单的实现逻辑更加便捷的路由配置...

js常用数组API方法汇总(js数组api有哪些)

1.push()向数组末尾添加一个或多个元素,并返回新的长度。//1.push()向数组末尾添加一个或多个元素,并返回新的长度。constarr1=[1,2,3];const...

JavaScript 数组操作方法大全(js数组的用法)

数组操作是JavaScript中非常重要也非常常用的技巧。本文整理了常用的数组操作方法(包括ES6的map、forEach、every、some、filter、find、from、of等)...

Array类型简介(arrays类常用方法)

Array类型除了Object之外,Array类型恐怕是ECMAScript中最常用的类型了。而且,ECMAScript中的数组与其他多数语言中的数组有着相当大的区别。虽然ECMAScript数组与其...

鸿蒙开发基础——TypeScript Array对象解析

数组对象是使用单独的变量名来存储一系列的值。TypeScript的数组对象提供了强大的类型支持,确保数组操作的类型安全。...

js中splice的用法,使用说明及例程

js中splice的用法,使用说明及例程。splice()方法用于添加或删除数组中的元素,使用起来很怪异。删除会影响原有数组,会返回删除的内容。例1,删除数组内容:varstr=["a&#...

JavaScript 时间复杂度分析指南(js算法复杂度)

...

3个 Vue $set 的应用场景(vue中set方法应用场景)

大家好,我是大澈!一个喜欢结交朋友、喜欢编程技术和科技前沿的老程序员,关注我,科技未来或许我能帮到你!...