MySQL中锁的必要性_MySQL中锁有何必要性及类别

MySQL中锁有何必要性及类别

发布时间:2020-06-04 10:50:35

来源:PHP中文网

阅读:116

作者:三月

下文主要给大家带来MySQL中锁有何必要性及类别,希望这些内容能够带给大家实际用处,这也是我编辑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通过锁机制来实现事务的隔离

锁的分类如下

4065b986d02738b9b1fea667d0147e73.png

对于以上关于MySQL中锁有何必要性及类别,大家是不是觉得非常有帮助。如果需要了解更多内容,请继续关注我们的行业资讯,相信你会喜欢上这些内容的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值