问答分享第一弹 Mysql锁机制,分为哪些锁,有什么样的特点?

Posted androidstarjack

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了问答分享第一弹 Mysql锁机制,分为哪些锁,有什么样的特点?相关的知识,希望对你有一定的参考价值。

点击上方蓝色“终端研发部”,选择“设为星标”

学最好的别人,做最好的我们 

大家好,前几天能分享了第一期面试题,mysql 中有哪几种锁 和 这些锁各有哪些特点 ,这道面试题是经常会被问到的一个面试题,大家反馈的都挺不错的。今天特此来总结一下。

核心

Mysql锁机制,分为哪些锁,有什么样的特点?

目标

  • 锁的分类

  • 锁的特点

  • 锁的应用场景

事务并发带来的问题与解决方案

补充

1.脏读:一个事务可以读取到另一个事务未提交的数据。如下图:

解决脏读:修改数据时加上写锁

不可重复读:在一个事务中不同时间段查询出现不同的结果,可能被更新可能被删除。如下图

解决不可重复读:事务A第一次读数据时加上读锁,事务B不能修改,会阻塞。

3.幻读:在一个事务中不同时间段查询,记录数不同。与不可重复读的区别是:在幻读中,已经读取的数据不会改变,只是与以前相比,会有更多的数据满足查询条件。如下图:

解决幻读:事务A范围查询时加上临键锁,锁住相邻区间,事务B不能插入到被锁住的区间,防止幻读。

答案揭晓

按锁粒度分类:

  • 1、行级锁

  • 2、表级锁

  • 3、页级锁

解释:

1、表级锁:开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高,并发度最低。

2、行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。

3、页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般。

按照锁级别分类 :

  • 1、共享锁

  • 2、排他锁

  • 3、意向锁

解释:

1、共享锁:一旦上锁,任何事务(包括当前事务)无法对其修改,其他事务可以并发读取数据,也可在对此数据再加共享锁

2、排他锁(独占锁):如果事务对数据A加上排他锁后,则其他事务不可并发读取数据,也不能再对A加任何类型的锁。获准排他锁的事务既能读数据,又能修改数据。

3、意向锁:分为意向共享锁和意向排他锁,特点:意向锁是InnoDB自动加的,不需要用户干预。

BAT等大厂Java面试经验总结 想获取 Java大厂面试题学习资料扫下方二维码回复「BAT」就好了回复 【加群】获取github掘金交流群回复 【电子书】获取2020电子书教程回复 【C】获取全套C语言学习知识手册回复 【Java】获取java相关的视频教程和资料回复 【爬虫】获取SpringCloud相关多的学习资料回复 【Python】即可获得Python基础到进阶的学习教程回复 【idea破解】即可获得intellij idea相关的破解教程关注我gitHub掘金,每天发掘一篇好项目,学习技术不迷路!



回复 【idea激活】即可获得idea的激活方式
回复 【Java】获取java相关的视频教程和资料
回复 【SpringCloud】获取SpringCloud相关多的学习资料
回复 【python】获取全套0基础Python知识手册
回复 【2020】获取2020java相关面试题教程
回复 【加群】即可加入终端研发部相关的技术交流群
阅读更多
为什么HTTPS是安全的
因为BitMap,白白搭进去8台服务器...
《某厂内部SQL大全 》.PDF
字节跳动一面:i++ 是线程安全的吗?
大家好,欢迎加我微信,很高兴认识你!
在华为鸿蒙 OS 上尝鲜,我的第一个“hello world”,起飞!

相信自己,没有做不到的,只有想不到的在这里获得的不仅仅是技术!



就给个“在看”

以上是关于问答分享第一弹 Mysql锁机制,分为哪些锁,有什么样的特点?的主要内容,如果未能解决你的问题,请参考以下文章

问答分享第一弹MySQL锁总结:MySQL行锁表锁排他锁共享锁的特点

mysql共享锁与排他锁

-mysql-锁机制分为表级锁和行级锁

Mysql的共享锁和排他锁(转载)

MySQL锁机制&&PHP锁机制,应用在哪些场景中呢?

#yyds干货盘点#盘点MySQL的锁机制是如何实现的