数据库的锁是在多线程高并发的情况下用来保证数据稳定性和一致性的一种机制。MySQL 根据底层存储引擎的不同,锁的支持粒度和实现机制也不同。MyISAM 只支持表锁,InnoDB 支持行锁和表锁。目前 MySQL 默认的存储引擎是 InnoDB,这里主要介绍 InnoDB 的锁。
使用 InnoDB 的两大优点:一是支持事务;二是支持行锁。
在高并发的情况下事务的并发处理会带来几个问题
由于高并发事务带来这几个问题,所以就产生了事务的隔离级别
举个例子
按照上面 1,2,3,4 的顺序执行会发现第 4 步被阻塞了,必须执行完第 5 步后才能插入成功。这里我们会很奇怪明明锁住的是uid=6 的这一行,为什么不能插入 5 呢?原因就是这里采用了 next-key 的算法,锁住的是(3,10)整个区间。感兴趣的可以试一下。
今天给大家分享了一下 MySQL 的 InnoDB 的事务以及锁的一些知识,通过自己的实际上手实践对这块更加熟悉了,希望大家在看的时候也可以动手试试,这样更能体会,理解的更深刻。
乐观锁,悲观锁,这两个概念你需要搞清楚才能更好的理解。乐观锁:与悲观锁相对应,不是数据库自带的,需要自己去实现。
悲观锁:与乐观锁相对应,是数据库自己实现了的。要用的时候,我们直接调用数据库的相关语句就可以了。
悲观锁又涉及到其他两个锁概念,共享锁和排他锁。只有去理解和实际 *** 作才能更好的理解这些具体的东西。
希望我的回答对你有所帮助
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)