mysql 不同事务隔离级别

Posted devilwind

tags:

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

repeatable read 在同一事务中,同一查询多次进行时候,由于其他插入操作(insert)的事务提交,导致每次返回不同的结果集。

标准的repeatable read是允许幻读的,因为这一级别只在读取过的纪录上加共享锁,防止别其它事务修改,但是不禁止其它人插入新数据.

当第一次读的时候,他们就被固化(快照)了,自己再也无法发现他们的任何变化,但是却不禁止其它人修改删除插入.

 

这种级别适合做什么呢? 其实不太适合一般的联机交易类似,而更适合统计查询报表类需求.

比如,我们需要根据一些明细,统计数据,并将结果保存到另外几张表中,也就是无法通过一个SQL完成,使用mysql RR就比较合适

begn work

insert into tj1 select * from t where ....

insert into tj2 select * from t where ....

commit

 

 

如果使用read commit级别,tj1插入后,t可能被修改新增删除,那么随后的tj2结果就可能与tj1的基础数据不一致.

但是使用RR级别就不存在这个问题.因此第一次读就被固化了.即便t随后被清空,也不影响tj2的结果.

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

MySQL事务隔离级别-案例驱动

2Mysql事务的隔离级别?

MYSQL的事务隔离级别,MVCC,readView和版本链小结

mysql -- 事务隔离级别以及java中事务提交的步骤

mysql事务隔离级别测试

简述mysql的事务隔离级别都有哪些