MySQL(26):事务的隔离级别出现问题之 幻读
1. 幻读
幻读(Phantom Read)又称为虚读,是指在一个事务内两次查询中数据条数不一致,幻读和不重复读有些类型,同样是在两次查询过程中,不同的是,幻读是由于其他事务做了插入记录的操作,导致记录数有所增加。
例如:银行在做统计报表时统计account表中所有用户的总金额时候,此时总共有三个账户,总共金额为3000元,这时候新增了一个用户账户,并且存入1000元,这时候银行再次统计就会发现账户总金额为4000,造成了幻读情况
2. 演示幻读:
(1)首先我们设置b账户的隔离级别
b账户:由于前面将事务个隔离级别设置为可重复读,这种隔离级别是可以避免幻读的出现,因此需要将事务的隔离级别设置为更低,下面将事务的隔离级别设置为
Read Committed,具体语句如下:
set session transaction isolation level read committed;
上述语句执行完成之后,b账户事务的隔离级别为Read Committed

(2)演示幻读:
b账户:首先在b账户中开启一个事务,然后在当前事务中查询账户的余额信息,查询结果如下:

a账户:在对a账户进行添加操作之前,使用select语句查看当前a账户中的信息,执行结果如下:

接下来对a账户进行添加操作,a账户不用开启事务,直接执行添加操作即可,具体语句如下:
insert into account(name,money) values('c',);
执行结果如下:

b账户:当a账户添加记录完成之后,可以在b账户中再次查询场合余额信息,如下:

通过对比b账户设置Read Committed隔离级别前后,发现第二次查询数据时比第一查询数据时候多一条记录,这种情况并不是错误的,但可能不符合实际需求。需要注意的是,上述情况演示完成之后,将b账户中的事务提交。
3. 解决问题:
(1)重新设置b账户的隔离级别
b账户:为了防止出现幻读,可以将b账户的隔离级别设置为Repeatable Read,具体语句如下:
set session transaction isolation level repeatable read;
上述的语句执行完毕之后,事务隔离级别设置为Repeatable Read

(2)重新验证是否出现幻读
b账户:在b账户中重新开启一个事务,并在该事务中查询当前账户的余额信息,查询结果如下:

a账户:对a账户进行添加操作之前,使用select语句查看当前的a账户的余额信息,执行语句结果如下:

接下来对账户a进行添加操作,在a账户中不开启事务,直接执行添加操作,具体语句如下:
insert into account(name,money) values('d',);
执行结果如下:

b账户:当a账户的添加操作执行成功之后,再次查询当前账户的余额信息,查询结果如下:

对比b账户两次查询的结果,发现两者都是一致的。并没有出现重复读取的情况,因此可以说明当前事务的隔离级别可以避免幻读,最后还有使用commit语句提交当前事务,提交之后,b账户查询结果如下:

MySQL(26):事务的隔离级别出现问题之 幻读的更多相关文章
- Mysql数据库事务的隔离级别和锁的实现原理分析
Mysql数据库事务的隔离级别和锁的实现原理分析 找到大神了:http://blog.csdn.net/tangkund3218/article/details/51753243 InnoDB使用MV ...
- Mysql 间隙锁原理,以及Repeatable Read隔离级别下可以防止幻读原理(百度)
Mysql知识实在太丰富了,前几天百度的面试官问我MySql在Repeatable Read下面是否会有幻读出现,我说按照事务的特性当然会有, 但是面试官却说 Mysql 在Repeatable Re ...
- 浅析SQL Server在可序列化隔离级别下,防止幻读的范围锁的锁定问题
本文出处:http://www.cnblogs.com/wy123/p/7501261.html (保留出处并非什么原创作品权利,本人拙作还远远达不到,仅仅是为了链接到原文,因为后续对可能存在的一些错 ...
- 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的理 ...
- MySQL数据库事务各隔离级别加锁情况--read uncommitted篇(转)
本文转自https://m.imooc.com/article/details?article_id=17291,感谢作者 1.目的 1.1 合适人群 1.数据库事务特征我只是背过,并没有很深刻的理解 ...
- Mysql数据库事务及隔离级别学习测试
参考了这篇文章的一些内容: http://xm-king.iteye.com/blog/770721 记住以下这张表: 我在springdemo库里面建了一个表: CREATE TABLE `tx` ...
- SQL Server中的事务与其隔离级别之脏读, 未提交读,不可重复读和幻读
原本打算写有关 SSIS Package 中的事务控制过程的,但是发现很多基本的概念还是需要有 SQL Server 事务和事务的隔离级别做基础铺垫.所以花了点时间,把 SQL Server 数据库中 ...
- 一文搞定MySQL的事务和隔离级别
一.事务简介 事务是数据库管理系统执行过程中的一个逻辑单位,由一个有限的数据库操作序列构成. 一个数据库事务通常包含了一个序列的对数据库的读/写操作.它的存在包含有以下两个目的: 为数据库操作序列提供 ...
随机推荐
- 常见的mongo shell命令
启动mongo shell 在windows下,双击mongo.exe可以启动mongo shell 查询库.表及选择库 查询所有库命令: show dbs 应用某一个db use jxs_datab ...
- JSP文件下载时文件名在ie和firefox下面文件名不一致极其超链接中文乱码的问题的改进
response.setContentType("application/octet-stream;charset=UTF-8"); fileName=java.net.URLEn ...
- Android Studio使用JNI
0x01 前言 本文讲述使用Android Studio通过静态注册.动态注册使用JNI的方法,以及加载第三方so文件的方法 0x02 Android Studio静态注册的方式使用JNI 1. 添加 ...
- Https如何保证安全
Https加密安全. SSL加密. Https和http的区别?Https如何做到安全? HTTPS协议是由SSL+HTTP协议构建的可进行加密传输.身份认证的网络协议. http是普通的超文本文 ...
- 无责任Windows Azure SDK .NET开发入门篇三[使用Azure AD 管理用户信息]
三.使用Azure AD管理用户信息 在上一章我们采用OpenID的方案和Azure AD交互进行身份验证,本章节我们继续了解如何在Azure AD中创建用户,列出用户信息,修改用户信息和删除用户信息 ...
- C++100款开源界面库[转]
(声明:Alberl以后说到开源库,一般都是指著名的.或者不著名但维护至少3年以上的.那些把代码一扔就没下文的,Alberl不称之为开源库,只称为开源代码.这里并不是贬低,像Alberl前面那个系列的 ...
- Flex应用程序如何启动
Flex应用程序启动 编写一个简单的Flex应用程序并不复杂,就算你从来没接触过Flex程序设计,照着帮助的实例步骤,不需花多长时间也能做出一个漂亮简捷的小程序出来.不过,随着对Flex程序编写的深入 ...
- ASSER、VERIFY、TRACE详解
ASSERT()被测试它的参数,如果参数为零,则中断执行并打印一段说明消息.在Release版本的程序中它不起任何作用. ASSERT()使用的时候必须保证参数表达式中不能有函数调用,因此对于任何有函 ...
- 【6】连续序列和为s
题目:输入一个整数s,打印出全部和为s的连续整数序列(至少含有2个数).比如输入9,则输出2.3.4和4.5两个序列 方案一:因为序列至少要2个数,则两个数上限值为(1+s)/2,我们能够枚举该序列的 ...
- 【转】larbin主要代码说明
转自:http://blog.csdn.net/s030702614/article/details/5683928 1. 主函数: int main (int argc, char *argv[]) ...