MySQL中的锁之一:锁的必要性及分类
当用户访问量增长时,数据库往往是一个系统的性能瓶颈,但不光光是性能瓶颈,数据安全也会随之浮现,这时候锁机制就非常有必要。 并发造成的数据安全问题主要分为3个方面:脏读、幻读、不可重复读
一. 脏读
脏读就是一个事务读取到了另一个事务未提交的数据。
时间线 事务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 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 begin; select * from lock where id = 1; begin; update lock set name='non-rr'; commit; select * from lock where id = 1; commit;
MySQL通过对事务的隔离来解决以上三种问题
共有4种隔离级别
隔离级别 脏读 幻读 不可重复读 未提交读(RUC) 是 是 是 已提交读(RC) 否 是 是 可重复读(RR) 否 是 否 可串行化 否 否 否
MySQL通过锁机制来实现事务的隔离
锁的分类如下
相关推荐
DriveCar 2020-09-07
quniMdejiangyou 2020-08-15
qingjiuquan 2020-07-18
zhanbuquan 2020-07-04
liaomingwu 2020-06-25
lpfvip00 2020-06-25
zhanbuquan 2020-06-21
daillo 2020-06-17
sunysh00 2020-06-11
vincen 2020-06-10
langyue 2020-06-09
DriveCar 2020-06-09
airfling 2020-06-08
sofast 2020-06-03
weikaixxxxxx 2020-05-30
neweastsun 2020-05-27
sunysh00 2020-05-25
silencehgt 2020-07-04
variab 2020-06-13
zjx0 2020-05-20
愿天下再无BUG 2020-05-16
pengpengflyjhp 2020-05-14
MissFuTT 2020-05-11
inhumming 2020-05-10
好记忆也需烂 2020-05-10
silencehgt 2020-05-09