查询修改mysql事务隔离级别

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了查询修改mysql事务隔离级别相关的知识,希望对你有一定的参考价值。

1.查看当前会话隔离级别

select @@tx_isolation; 

2.查看系统当前隔离级别

select @@global.tx_isolation;

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

set tx_isolation=‘read-committed‘;

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

set global transaction isolation level read committed;

关于隔离级别的理解:

1.read uncommitted

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

2.read committed

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

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

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

4.serializable

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

 

关于隔离级别的理解参考了andyhu1007的文章:http://www.iteye.com/topic/322382


本文出自 “梦Dream” 博客,请务必保留此出处http://dreamy.blog.51cto.com/12471447/1906042

以上是关于查询修改mysql事务隔离级别的主要内容,如果未能解决你的问题,请参考以下文章

事务的隔离级别和mysql事务隔离级别修改

MySQL的默认事务隔离级别是?

MySQL:事务四大特性与隔离级别

Mysql--事务的隔离级别

mysql 事务隔离级别 详解

如何更改mysql事务隔离级别