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,这个有待于以后实际测试。