MySQL中锁的必要性及分类介绍
本篇文章给大家带来的内容是关于MySQL中锁的必要性及分类介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
当用户访问量增长时,数据库往往是一个系统的性能瓶颈,但不光光是性能瓶颈,数据安全也会随之浮现,这时候锁机制就非常有必要。
并发造成的数据安全问题主要分为3个方面:脏读、幻读、不可重复读
一. 脏读
脏读就是一个事务读取到了另一个事务未提交的数据。时间线事务1事务21begin;2select * from lock where id = 1;3begin;4update lock set name='dirty';6select * from lock where id = 1;7commit;commit;二. 幻读
幻读就是一个事务读到了另一个事务insert的数据时间线事务1事务21begin;2select * from lock where id > 1;3begin;4insert lock select 2;5commit;6select * from lock where id > 1;7commit;三. 不可重复读
不可重复读就是多次读取统一数据返回的结果不一致。同脏读不同,这是读取已经提交的数据;同幻读也不同,这边是更新数据,幻读是插入数据。时间线事务1事务2begin;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中锁的必要性及分类介绍的详细内容,更多请关注小潘博客其它相关文章!