博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
read view初探
阅读量:4983 次
发布时间:2019-06-12

本文共 1546 字,大约阅读时间需要 5 分钟。

innodb为实现MVCC所使用的内部快照,RR(REPEATABLE READ)隔离级别下在第一次查询时创建read view,RC(READ COMMITTED)隔离级别下会在每次查询时创建read view

以下测试在RR隔离级别下,数据库版本为5.7.20
1.

session A session B
start transaction;  
  start transaction;

select * from tab1;

Empty set

 
  insert into tab1 values (1,"1");

select * from tab1;

Empty set

 
  commit;

select * from tab1;

Empty set

 

commit;

 

select * from tab1;

+------+------+
| col1 | col2 |
+------+------+
| 1 | 1 |
+------+------+

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

结论:在已经查询后,其他事务做的修改,在本事务不可见

2.

session A session B
truncate table tab1;  

start transaction;

 
  start transaction;
  insert into tab1 values (1,"1");
  commit;

select * from tab1;

+------+------+
| col1 | col2 |
+------+------+
| 1 | 1 |
+------+------+

 

 

 

 

 

 

 

 

 

 

 

 

结论:尽管事务A比事务B先开始,但是第一次查询在B事务提交后,所以可以查询到结果

3.

session A session B
truncate table tab1;  

start transaction;

 
  start transaction;

select * from tab1;

Empty set

 
  insert into tab1 values (1,"1");
  insert into tab1 values (2,"2");
  insert into tab1 values (3,"3");
  commit;

select * from tab1;

Empty set

 

update tab1 set col2 ="22" where col1>=2;

2 rows affected

 

select * from tab1;

+------+------+
| col1 | col2 |
+------+------+
| 2 | 22 |
| 3 | 22 |
+------+------+

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

结论:虽然事务A看不到事务B做的修改,但是修改也会影响事务B已经提交的数据,且修改发生后,被修改的记录(尽管是其他事务提交的),也会变为对该事务可见

另外:

1.select ... for update和select ... lock in share mode(8.0是select ... for share)会重新生成read view

2.select ... with consistent snapshot不会读到在本事务开始后提交的数据,即使第一次select是在其他事务提交后

 

 

参考网址:

1. https://dev.mysql.com/doc/refman/5.6/en/innodb-consistent-read.html

2. http://kabike.iteye.com/blog/1820553

转载于:https://www.cnblogs.com/wangzheng1024/p/9403361.html

你可能感兴趣的文章
Thinkphp控制器,1.多层控制器2.多级控制器
查看>>
继续聊WPF——如何获取ListView中选中的项
查看>>
软碟通制作fedora17 U盘启动的方法
查看>>
MyGrowStack
查看>>
php加密解密处理类
查看>>
幽默数
查看>>
软件测试_lab2_Selenium自动化
查看>>
简易计算器软件的典型用户和 场景
查看>>
oracle instantclient_12_2安装
查看>>
2005年华中科技大学计算机保研机试真题 找位置
查看>>
windows环境下MySQL-5.7.12-winx64下载安装与配置
查看>>
怎么查看电脑开关机时间记录
查看>>
position标签
查看>>
Web Worker模拟抢票
查看>>
应用在AppStore检测版本更新
查看>>
【Data】数据结构之线性表(3)
查看>>
OpenGL tutorial资源在mac yosemite下的cmake生成工程问题
查看>>
java—将数据库读取的list转tree
查看>>
关于C51 keil使用中.c文件的链接心得
查看>>
Ios 弹框 MJPopup,KxMenu
查看>>