form1.cn
Make a little progress every day

查询与设置mysql事务隔离级别

10th of January 2019 Database Mysql 2133

所有级别

1)read uncommitted : 读取尚未提交的数据 :哪个问题都不能解决
2)read committed:读取已经提交的数据 :可以解决脏读 ---- oracle默认的
3)repeatable read:重读读取:可以解决脏读 和 不可重复读 ---mysql默认的
4)serializable:串行化:可以解决 脏读 不可重复读 和 虚读---相当于锁表


1.查看当前会话隔离级别(当前数据库)

select @@tx_isolation;


2.查看系统当前隔离级别(整个mysql系统)

select @@global.tx_isolation;


2.5.查询当前会员和系统隔离级别

select @@global.tx_isolation,@@tx_isolation;


3.设置当前会话隔离级别

set session transaction isolation level repeatable read;


4.设置系统当前隔离级别

set global transaction isolation level repeatable read;


5.命令行,开始事务时

set autocommit=off 或者 start transaction


6.查看sutocommit状态,两种都一样

select @@autocommit;  # 值为1代表每一条sql可自动提交,0为必须在sql后commit手动提交
SHOW VARIABLES LIKE '%AUTOCOMMIT%'; # 值为ON代表每一条sql可自动提交,OFF为必须在sql后commit手动提交

参考:http://www.cnblogs.com/chedanlangren/p/8318673.html

 

关于隔离级别的理解

1.read uncommitted

可以看到未提交的数据(脏读),举个例子:别人说的话你都相信了,但是可能他只是说说,并不实际做。


2.read committed

读取提交的数据。但是,可能多次读取的数据结果不一致(不可重复读,幻读)。用读写的观点就是:读取的行数据,可以写。


3.repeatable read(MySQL默认隔离级别)

可以重复读取,但有幻读。读写观点:读取的数据行不可写,但是可以往表中新增数据。在MySQL中,其他事务新增的数据,看不到,不会产生幻读。采用多版本并发控制(MVCC)机制解决幻读问题。


4.serializable

可读,不可写。像java中的锁,写数据必须等待另一个事务结束。

mysql中事务隔离级别为serializable时会锁表,因此不会出现幻读的情况,这种隔离级别并发性极低,开发中很少会用到。


MySQL事务隔离级别


事务隔离级别脏读不可重复读幻读
读未提交(read-uncommitted)
不可重复读(read-committed)
可重复读(repeatable-read)
串行化(serializable)