MySQL中事务的隔离级别
MySQl InnoDB存储引擎实现SQL标准的4种隔离级别(RU,RC,RR,serializable),用来限定事务内外的哪些改变时可见的,哪些时不可见的。低级别的隔离级一般支持更高的并发处理,并拥有更低的系统开销。MySQL数据库通过show variables like '%tx_isolation%'
命令来查看当前数据库的隔离级别。比如,我的电脑上执行此指令的结果如下:
Variable_name |Value |
--------------|----------------|
tx_isolation |REPEATABLE-READ |
可以通过set global|session transaction isolation level
命令修改全局或者当前会话的事务隔离级别。
目前MySQL版本默认的隔离界别时REPEATABLE-READ
。
4种隔离级别:
- 读未提交(read uncommitted),简称 RU —— 在其中一个事务中,可以读取到其他事务未提交的数据变化。这种读取其他绘画还没提交的事务,叫做 脏读 现象。在生产环境中不建议使用。
- 读已提交(read committed),简称 RC —— 在其中一个事务中,可以读取到其他事务已经提交的数据变化。这种读取也可以叫做 不可重复读 ,允许 幻读 现象的发生,是Oracle数据库默认的事务隔离级别。
- 可重复读(repeatable read),简称 RR ,它是MySQL默认的事务隔离级别——在其中一个事务中,直到事务结束前,都可以反复读取到事务刚开始时看到的数据,并一直不会发生变化,避免了脏读、不可重复读和幻读现象的发生。
- 串行(serializable)—— 在每个读的数据行上都需要加表级共享锁,在每次写数据时都需要加表级排他锁。着就会造成InnoDB的并发能力下降,大量的超时和锁竞争就会发生。不建议使用到生产环境中。
对于RU、RR、RC可以这么理解,举个例子:
你要去一个长达十年的星际旅行。
在旅行前,你和你的女朋友做最后一次告别。
如果在告别前,你的女朋友给了你一张他的照片。
每次你在宇宙飞船上寂寞的时候,都会看看你女朋友的这张照片,而这张照片上面你的女朋友一直都没有变。这就是 可重复读(RR) 。
如果你在宇宙飞船上可以和你的女朋友进行视频聊天,而每次视频聊天之前你的女朋友都会化妆,画一个很好看的妆,然后美美地和你视频聊天(我们假设每次化妆相当于女朋友这个事务进行了一次提交),你每次都可以看到你女朋友不同的妆容,那么这就是 读已提交(RC) 。
如果你任何时候都能和你的女朋友视频,但是有的时候你的女朋友还没有来得及化妆,而你的女朋友还是那种不化妆奇丑无比的,见光死的那种,虽然其实你的女朋友不想让你看到她没有化妆的样子,但是有的时候你的视频通话请求来的触不及防(可能就是她刚睡醒的时候),那么你不光能够看到她化妆的样子,还能看到她见光死的样子,这就是 读未提交(RU) 。
所以我们可以看到:
MySQL默认使用 可重复读 ,它的广告标语是: “让你看到我十年都不变的美貌!” 。
Oracle默认使用 读已提交 ,他的广告标语是:“每一次让你看到我都觉得美美的!” 。
不建议使用 读未提交 ,因为不化妆的你女朋友容易引起不适,引发分手问题。
当然,这只是你的女朋友,我的女朋友,即使不化妆,也是美美的(偷笑)。
MySQL中事务的隔离级别的更多相关文章
- MySQL数据库事务各隔离级别加锁情况--read committed && MVCC(转载)
http://www.imooc.com/article/17290 http://www.51testing.com/html/38/n-3720638.html https://dev.mysql ...
- MySQL数据库事务各隔离级别加锁情况--read committed && MVCC(转)
本文转自https://m.imooc.com/article/details?article_id=17290 感谢作者 上篇记录了我对MySQL 事务 隔离级别read uncommitted的理 ...
- Hibernate中事务的隔离级别设置
Hibernate中事务的隔离级别,如下方法分别为1/2/4/8. 在Hibernate配置文件中设置,设置代码如下
- Mysql数据库事务的隔离级别和锁的实现原理分析
Mysql数据库事务的隔离级别和锁的实现原理分析 找到大神了:http://blog.csdn.net/tangkund3218/article/details/51753243 InnoDB使用MV ...
- MySQL数据库事务各隔离级别加锁情况--read uncommitted篇(转)
本文转自https://m.imooc.com/article/details?article_id=17291,感谢作者 1.目的 1.1 合适人群 1.数据库事务特征我只是背过,并没有很深刻的理解 ...
- 高性能MySQL--innodb中事务的隔离级别与锁的关系
最近买了<高性能MySQL>这本书回来看,从中收益颇多!我来一吐为快! 我们都知道事务,那么在什么情况下我们需要使用事务呢? 银行应用是解释事务的一个经典例子.假设一个银行的数据库有两张表 ...
- 一文搞定MySQL的事务和隔离级别
一.事务简介 事务是数据库管理系统执行过程中的一个逻辑单位,由一个有限的数据库操作序列构成. 一个数据库事务通常包含了一个序列的对数据库的读/写操作.它的存在包含有以下两个目的: 为数据库操作序列提供 ...
- mysql的事务,隔离级别和锁
事务就是一组一起成功或一起失败的sql语句.事务还应该具备,原子性,一致性,隔离性和持久性. 一.事务的基本要素 (ACID) 1.原子性:事务开始后,所有的操作,要么全部成功,要么全部失败,不可能处 ...
- MySQL数据库事务各隔离级别加锁情况--Repeatable Read && MVCC(转)
本文转自https://m.imooc.com/article/details?article_id=17289 感谢作者 上节回顾 上两篇记录了我对MySQL 事务 隔离级别read uncommi ...
随机推荐
- 使用fastjson 进行jsonObject转实体类对象
使用fastjson 进行jsonObject转实体类对象 1 <dependency> 2 <groupId>com.alibaba</groupId> 3 ...
- vue创建组件的方式
一.直接通过Vue.extend的方式创建组件 // 通过vue.extend 来创建全局组件 var com1 = Vue.extend({ template:'<h3>这是h3组件&l ...
- shiro认证+盐加密
Shiro认证 导入pom依赖 <shiro.version>1.2.5</shiro.version> <!--shiro--> <dependency&g ...
- php流程控制 之循环语句的使用
循环语句的使用 王同学需要反复往返于北京和大连,就是典型的循环结构.假设王思总投资这个项目需要往返大连100次,每次往返都王同学都会计数一次.难道我们写一百遍同样的代码?显然对于智商极高的程序员来说不 ...
- 洛谷 P3375 【模板】KMP字符串匹配 题解
KMP模板,就不解释了 #include<iostream> #include<cstdio> #include<cstring> #include<algo ...
- React vs Angular vs Vue 2019
React vs Angular vs Vue 看待这三个主流框架给出的想法 Angular is the entire kitchen that gives you all the tools ne ...
- 桥接模式:探索JDBC底层实现
一.目录概要 二.问题探究 需求:假设要设计一个电脑商场管理系统的某个模块设计,电脑分为品牌和类型两个纬度,我们应该怎么解决? 按照初学者的思路,利用继承就能简单粗暴的实现,那我们来看下这种思路的设计 ...
- Solution
小五的游戏 小碎骨的子集 芙兰朵露的框框 ⑨要求和
- [golang]写了一个可以用 go 来写脚本的工具:gosl
转自:https://golangtc.com/t/53cca103320b52060a000030 写了一个可以用 go 来写脚本的工具:gosl 代码和使用说明可以看这里: http://gith ...
- 请解释或描述一下Django的架构
对于Django框架遵循MVC设计,并且有一个专有名词:MVT M全拼为Model,与MVC中的M功能相同,负责数据处理,内嵌了ORM框架 V全拼为View,与MVC中的C功能相同,接收HttpReq ...