美文网首页
2019-01-18

2019-01-18

作者: 宋song一 | 来源:发表于2019-01-18 22:47 被阅读2次

    1.MySQL事务隔离级别:事务隔离级别,解决什么并发问题,以及存在什么并发问题

    (1)READ_UNCOMMITTED (RU 为未提交读) 造成脏读
      这是事务最低的隔离级别,它充许另外一个事务可以看到这个事务未提交的数据。
      解决第一类丢失更新的问题,但是会出现脏读、不可重复读、第二类丢失更新的问题,幻读 。
    (2)READ_COMMITTED (RC 提交读) 造成幻读
      保证一个事务修改的数据提交后才能被另外一个事务读取,即另外一个事务不能读取该事务未提交的数据。
      解决第一类丢失更新和脏读的问题,但会出现不可重复读、第二类丢失更新的问题,幻读问题
    (3)REPEATABLE_READ (RR 可重复读)
      保证一个事务相同条件下前后两次获取的数据是一致的
    解决第一类丢失更新,脏读、不可重复读、第二类丢失更新的问题,但会出幻读。
    (4)SERIALIZABLE (SERI 序列化 完全串行化执行对应得事务)
      事务被处理为顺序执行。
      解决所有问题

    image.png

    MySql的隔离级别和锁的关系

    mysql 隔离级别与锁

    InnoDB引擎的锁机制:

    共享锁(S):允许一个事务去读一行,阻止其他事务获得相同数据集的排他锁。
    排他锁(X):允许获得排他锁的事务更新数据,阻止其他事务取得相同数据集的共享读锁和排他写锁。
    意向共享锁(IS):事务打算给数据行加行共享锁,事务在给一个数据行加共享锁前必须先取得该表的IS锁。
    意向排他锁(IX):事务打算给数据行加行排他锁,事务在给一个数据行加排他锁前必须先取得该表的IX锁。

    说明:

    1)共享锁和排他锁都是行锁,意向锁都是表锁,应用中我们只会使用到共享锁和排他锁,意向锁是mysql内部使用的,不需要用户干预。

    2)对于UPDATE、DELETE和INSERT语句,InnoDB会自动给涉及数据集加排他锁(X);对于普通SELECT语句,InnoDB不会加任何锁,事务可以通过以下语句显示给记录集加共享锁或排他锁。
    共享锁(S):SELECT * FROM table_name WHERE ... LOCK IN SHARE MODE。
    排他锁(X):SELECT * FROM table_name WHERE ... FOR UPDATE。

    3)InnoDB行锁是通过给索引上的索引项加锁来实现的,因此InnoDB这种行锁实现特点意味着:只有通过索引条件检索数据,InnoDB才使用行级锁,否则,InnoDB将使用表锁

    相关文章

      网友评论

          本文标题:2019-01-18

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