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 ...
随机推荐
- dedecms列表页使用noflag
最近小编使用dedecms遇到列表页需要使用noflag,在网上找了一圈都是直接替换代码,试用了一下并不能解决问题. 以下是小编自己根据资料整理的...多说一句由于各个编辑器打开的方式可能代码不在这一 ...
- ORA-609 错误分析及解决方法 (转载)
某个客户数据库在巡检的时候发现alert日志里不定期会出现ORA-609错误,大致内容如下: ***************************************************** ...
- Linux 一条长命令占用多行
前言 考察下面的脚本: ? 1 emcc -o ./dist/test.html --shell-file ./tmp.html --source-map-base dist -O3 -g4 --so ...
- 我们使用 Kafka 生产者在发消息的时候我们关注什么(Python 客户端 1.01 broker)
之前使用 Kafka 的客户端消费者比较多一点,而且也是无脑订阅使用也没有深入了解过具体的参数.总的来说使用不够细节. 这次公司项目活动期间暴露非常多的问题,于是有了这篇文章. 首先我们来拆解一下 K ...
- phpstorm 2019.1 修改选中内容背景色,以及匹配的内容背景色
#与选中内容匹配的内容背景色Editor -> Color Scheme -> General -> Code -> Identifier under caret #选中内容前 ...
- Consul常用接口使用
prometheus.yml 配置 - job_name: 'node_exporter' consul_sd_configs: - server: 'consul_ip:8500' services ...
- c#调用phantomjs 将 网页 存为 PDF
一. 下载 phantomjs 具体下载方式 不再详细说明了. 二. 创建一个 rasterize.js 文件 (放在哪里都行, 我这里是放在了项目中) . 代码内容如下 var page = req ...
- Android中进度条
<ProgressBar android:id="@+id/progress_bar" android:layout_width="match_parent&quo ...
- Android中活动被回收了怎么办
当一个活动进入到了停止状态,是有可能被系统回收的.按下返回键的时候,活动被重新创建一次,但是里面的数据就没办法重现: 这时Activity中提供了一个onSaveInstanceState()回调方法 ...
- 【CSP模拟赛】独立集(最长上升子序列&大力猜结论)
题目描述 有一天,一个名叫顺旺基的程序员从石头里诞生了.又有一天,他学会了冒泡排序和独 立集.在一个图里,独立集就是一个点集,满足任意两个点之间没有边.于是他就想把这两 个东西结合在一起.众所周知,独 ...