本篇文章给大家带来的内容是关于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;
三. 不可重复读
必应图像创建器
微软必应出品的AI绘图工具
453 查看详情
不可重复读就是多次读取统一数据返回的结果不一致。同脏读不同,这是读取已经提交的数据;同幻读也不同,这边是更新数据,幻读是插入数据。
时间线 事务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通过锁机制来实现事务的隔离
锁的分类如下

以上就是MySQL中锁的必要性及分类介绍的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/381243.html
微信扫一扫
支付宝扫一扫