黑马程序员技术交流社区

标题: 【上海校区】MySQL中锁的必要性及分类介绍  [打印本页]

作者: 梦缠绕的时候    时间: 2018-11-14 09:17
标题: 【上海校区】MySQL中锁的必要性及分类介绍 
本篇文章给大家带来的内容是关于MySQL中锁的必要性及分类介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

当用户访问量增长时,数据库往往是一个系统的性能瓶颈,但不光光是性能瓶颈,数据安全也会随之浮现,这时候锁机制就非常有必要。
并发造成的数据安全问题主要分为3个方面:脏读、幻读、不可重复读
一. 脏读
脏读就是一个事务读取到了另一个事务未提交的数据。
1
2
3
4
5
6
7
时间线  事务1                               事务2
  1    begin;                                 
  2    select * from lock where id = 1;
  3                                       begin;
  4                                       update lock set name='dirty';
  6    select * from lock where id = 1;
  7    commit;                            commit;

二. 幻读
幻读就是一个事务读到了另一个事务insert的数据
1
2
3
4
5
6
7
8
时间线       事务1                            事务2
   1        begin;
   2        select * from lock where id > 1;
   3                                        begin;
   4                                        insert lock select 2;
   5                                        commit;
   6        select * from lock where id > 1;
   7        commit;

三. 不可重复读
不可重复读就是多次读取统一数据返回的结果不一致。同脏读不同,这是读取已经提交的数据;同幻读也不同,这边是更新数据,幻读是插入数据。
1
2
3
4
5
6
7
8
时间线   事务1                            事务2
        begin;
        select * from lock where id = 1;
                                        begin;
                                        update lock set name='non-rr';
                                        commit;
        select * from lock where id = 1;
        commit;

MySQL通过对事务的隔离来解决以上三种问题
共有4种隔离级别
1
2
3
4
5
隔离级别           脏读   幻读   不可重复读
未提交读(RUC)       是     是      是
已提交读(RC)        否     是      是
可重复读(RR)        否     是      否
可串行化            否     否      否

MySQL通过锁机制来实现事务的隔离
锁的分类如下
以上就是MySQL中锁的必要性及分类介绍的详细内容


作者: 不二晨    时间: 2018-11-14 15:22
~(。≧3≦)ノ⌒☆
作者: 魔都黑马少年梦    时间: 2018-11-15 16:32





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2