美文网首页
mysql隔离级别

mysql隔离级别

作者: 浅浅星空 | 来源:发表于2020-06-19 16:30 被阅读0次
    image.png

    脏读

    当一个事务读取到另外一个事务修改但未提交的数据时,就可能发生脏读。

    image.png

    在我们的例子中,事务2修改了一行,但是没有提交,事务1读了这个没有提交的数据。现在如果事务2回滚了刚才的修改或者做了另外的修改的话,事务1中查到的数据就是不正确的了,所以这条数据就是脏读。

    不可重复读

    “不可重复读”现象发生在当执行SELECT 操作时没有获得读锁或者SELECT操作执行完后马上释放了读锁; 另外一个事务对数据进行了更新,读到了不同的结果.

    image.png

    在这个例子中,事务2提交成功,因此他对id为1的行的修改就对其他事务可见了。导致了事务1在此前读的age=1,第二次读的age=2,两次结果不一致,这就是不可重复读.

    幻读

    “幻读”又叫"幻象读",是''不可重复读''的一种特殊场景:当事务1两次执行''SELECT ... WHERE''检索一定范围内数据的操作中间,事务2在这个表中创建了(如[[INSERT]])了一行新数据,这条新数据正好满足事务1的“WHERE”子句。

    image.png

    如图事务1执行了两遍同样的查询语句,第二遍比第一遍多出了一条数据,这就是幻读。

    三者到底什么区别

    三者的场景介绍完,但是一定仍然有很多同学搞不清楚,它们到底有什么区别,我总结一下.

    脏读:指读到了其他事务未提交的数据.
    不可重复读: 读到了其他事务已提交的数据(update).

    不可重复读与幻读都是读到其他事务已提交的数据,但是它们针对点不同.
    不可重复读:update.
    幻读:delete,insert.

    https://juejin.im/post/5eeaf907f265da02d13c65e7

    相关文章

      网友评论

          本文标题:mysql隔离级别

          本文链接:https://www.haomeiwen.com/subject/nffbxktx.html