欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

mysql事务隔离级别实验

程序员文章站 2022-06-19 17:02:15
一、实验数据: 建表语句: CREATE TABLE `isolation` ( `id` int(11) NOT NULL, `name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_croatian_ci DEFAULT NULL, PR ......

一、实验数据:

建表语句:

create table `isolation` (
`id` int(11) not null,
`name` varchar(255) character set utf8mb4 collate utf8mb4_croatian_ci default null,
primary key (`id`)
) engine=innodb default charset=utf8mb4

 

创建表名为:isolation的表,其中有两个字段,一个 id ,一个 name

原始数据:

insert into isolation values(1,'name1'),(2,'name2'),(3,'name3');

插入三条记录。

二、准备:

分别打开两个mysql客户端a 、b

查看当前客户端隔离级别

select @@tx_isolation

mysql事务隔离级别实验

 mysql innodb默认隔离级别为可重复读。

 

设置b客户端不自动提交:

查看自动提交设置:

show session variables like 'autocommit';

mysql事务隔离级别实验

mysql innodb默认自动提交。

设置不自动提交:

set session autocommit=0;

mysql事务隔离级别实验

客户端设置不自动提交事物成功。 

一、脏读实验开始---------------------------------------

设置a的隔离级别为读未提交:

set session transaction isolation level read uncommitted;

客户端b启动一个事物

mysql事务隔离级别实验

mysql事务隔离级别实验

发现update的数据没有提交就读到了,回滚之后导致脏读。

 

mysql事务隔离级别实验

发现insert的数据没有提交就读到了,回滚之后导致脏读。

 

mysql事务隔离级别实验

发现delete的数据没有提交就读到了,回滚之后导致脏读。

脏读实验结束---------------------------------------

结论,脏读会读没有提交的update insert delete。

 

读已提交实验开始---------------------------------------

设置a的隔离级别为读已提交:

set session transaction isolation level read committed;

mysql事务隔离级别实验

update的时候------>>>发现解决了脏读,但是在一个事物里面,两次查询的结果不一致,即解决不了重复读的问题

mysql事务隔离级别实验

insert的时候------>>>发现解决了脏读,但是在一个事物里面,两次查询的结果不一致,即解决不了重复读的问题

mysql事务隔离级别实验

delete的时候------>>>发现解决了脏读,但是在一个事物里面,两次查询的结果不一致,即解决不了重复读的问题

 读已提交实验结束---------------------------------------

结论:解决了脏读,但是一个事物里面,同一个查询结果不一致,不能解决重复读的问题。

 

可重复读实验开始---------------------------------------

数据重新清理一下:

mysql事务隔离级别实验

update的时候------>>>在一个事物里面,两次查询直间,读不到另外事物提交的内容,只有提交当前事物,新启事物查询的时候才能查到更新的,即解决不了重复读的问题

 mysql事务隔离级别实验

delete的时候------>>>在一个事物里面,两次查询直间,读不到另外事物提交的内容,只有提交当前事物,新启事物查询的时候才能查到更新的,即解决不了重复读的问题

mysql事务隔离级别实验

 

 insert的时候------>>>在一个事物里面,两次查询直间,读不到另外事物提交的内容,只有提交当前事物,新启事物查询的时候才能查到更新的,即解决不了重复读的问题

可重复读实验结束---------------------------------------

结论:解决了脏读,可重复读,好像mysql 5.7.26在可重复读隔离级别解决了 幻想读的现象(猜测,还没太明白)。

 

串行化读实验开始---------------------------------------

mysql事务隔离级别实验

串行化读实验结束--------------------------------------

结论:串行化后,当一个事物没有提交,另外的事物不能修改对数据进行(update,insert,delete操作)。