当前位置: 移动技术网 > IT编程>开发语言>Java > mysql事务隔离级别实验

mysql事务隔离级别实验

2019年06月07日  | 移动技术网IT编程  | 我要评论
一、实验数据: 建表语句: 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 innodb默认隔离级别为可重复读。

 

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

查看自动提交设置:

show session variables like 'autocommit';

mysql innodb默认自动提交。

设置不自动提交:

set session autocommit=0;

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

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

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

set session transaction isolation level read uncommitted;

客户端b启动一个事物

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

 

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

 

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

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

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

 

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

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

set session transaction isolation level read committed;

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

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

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

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

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

 

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

数据重新清理一下:

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

 

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

 

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

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

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

 

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

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

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

如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网