代码改变世界

Mysql事务隔离级别学习

2015-08-17 15:07  唐伯虎点炮仗  阅读(254)  评论(0编辑  收藏  举报

这篇文章主要谈谈Mysql事务隔离级别的区别,以及自己的一些感受。

自己一直以来没搞懂“可重复读”和可提交读“两者之间的区别,通过此次的实践,清楚了两者之间的区别。废话不说,先上图看看这几个事务隔离级别。

Mysql数据库总共分为四个事务隔离级别,其中默认的事务隔离级别是:repeatable read,而与其它的数据库不同的是,其它的数据库默认事务隔离级别是read committed(SQL Server、Oracle)。

第一步:SERIALIZABLE

Instance 1:

Instance 2:

可以看到,第二个事务会被BLOCK住,一致显示正在执行中,最终会显示超时。

总结:SERIALIZABLE的事务隔离级别是:在一个事务没有执行完毕之前,第二个事务是无法继续执行的;这也与SERIALIZABLE是顺序执行事务这一点相吻合。

 

第二步:REPEATABLE READ

Instance 1:

Instance 2:

可以看到,在将数据库事务隔离级别设置为REPEATABLE READ之后,第一个事务在执行插入并提交之后,第二个事务并没有查询到插入的记录。这就是数据库中的“幻读”现象,但是在SERIALIZABLE级别下就不会出现这种现象。

总结:REPEATABLE READ级别并没有SERIALIZABLE级别隔离程度高,会导致“幻读”现象。

 

第三步:READ COMMITTED

Instance 1:

Instance 2:

可以看到,在第一个事务插入一条记录并且提交之后,在第二个事务中能看到插入的记录。

总结:READ COMMITTED顾名思义,可以读到已经提交的数据,但这也会造成同一个用户运行同一个语句两次,可能会得到不同的结果。

 

第四步:READ UNCOMMITTED

Instance 1:

Instance 2:

可以看到,READ UNCOMMITTED级别甚至可以读取到未提交的数据,这是相当危险的!如果事务由于其它原因回滚了,就会读取到已经弃用的数据。

总结:READ UNCOMMITTED是四个事务隔离级别中最低的,可以读取到未提交的数据。

 

开放学习:四个事务隔离级别的性能应当是:serializable<repeatable read<read committed<read uncommitted,这个有待于以后实际测试。