美团二面时被问到MySQL的InnoDB锁的类型和区别,答完以后面试官说整体是对的,但是细节上有点问题,想问问各路大神,这样回答是哪里不对吗?回答如下:
共享锁与排他锁:
lock in share mode:共享锁,可用于读锁
for update:排他锁,可用于写锁
共享锁与排他锁之间互相排斥(读写互斥)
共享锁与排他锁之间不排斥(读读共享)
排他锁与排他锁之间互相排斥(写写互斥)
InnoDB有行级锁(行级别)。
主键索引或唯一索引:行级锁
非唯一索引:Next-Key Lock = 行级锁+间隙锁gap(防止幻读)
无索引:退化为表级锁
InnoDB有意向锁(表级别)。
当其他事务需要获取表级锁时(如:无索引退化未表级锁),需要逐行检查是否其他事务获取了行级锁,效率会低。因此当其他事务获取锁时,会加一个意向锁,这样当其他事务需要获取表级锁时就不用逐行检查,只要判断是否有意向锁就可以了,有则阻塞。
全部评论
膜拜大佬,真的难
2 回复 分享
发布于 2022-04-01 18:21
我觉得面试官想你说说MVCC,现在就算是事务,默认也是不加for update和lock in share mode,最常用的你没说
1 回复 分享
发布于 2022-04-16 10:50
问到一样的了,问我myIsam和innodb的区别
点赞 回复 分享
发布于 2022-05-11 21:16
字节跳动校招内推码: HC9H2MF 投递链接: https://jobs.toutiao.com/s/FNmxaGn 本部门 JAVA 实习(三亚,北京,上海,杭州都可以奥): 字节跳动校招内推码: HC9H2MF 投递链接: https://jobs.toutiao.com/s/FNmmYYc map.put(0,' w'); map.put(1,'a'); map.put(2,'n'); map.put(3,'g'); map.put(4,'w'); map.put(5,'e'); map.put(6,'n'); map.put(7,'h'); map.put(8,'a'); map.put(9,'n'); map.put(10,'2013'); Print('W_ _X',' map.values()') 可沟通进度等
点赞 回复 分享
发布于 2022-04-27 18:54
除了for update也是适用于读锁之外,感觉也没啥问题
点赞 回复 分享
发布于 2022-04-19 21:07
主键索引或唯一索引:如果等值匹配找不到的话, 是不是会退化成 间隙锁呀?
点赞 回复 分享
发布于 2022-04-10 22:48
这不答得挺好的
点赞 回复 分享
发布于 2022-04-09 09:53

相关推荐

07-25 10:31
门头沟学院 Java
求问各位大佬,笔试都考点啥
投递科大讯飞等公司10个岗位
点赞 评论 收藏
分享
07-11 22:27
中南大学 Java
程序员牛肉:学历的话没问题。但是没问题的也就只有学历了。 其实你的整体架构是正确的,博客接着干。但是项目有点过于简单了。从后端的角度上讲,你这也就是刚入门的水平,所以肯定约面试够呛。 如果你要应聘后端岗位,那你第一个项目竟然是仿写操作系统。这个你要面试官咋问你。你一定要记住一点,你简历上写的所有的东西,都是为了证明你有能力胜任当前的岗位,而不是为了证明你自己会什么。 如果你只是浅浅的做几个项目,描述也都是烂大街。技术点也都是各种混水类的配置类需求,那你就不要幻想自己能走多远。一定要保持思考,保持学习。
点赞 评论 收藏
分享
allin秋招的单身...:我投过这家 上来就发个设计图给我,让我做好发到他邮箱
点赞 评论 收藏
分享
评论
10
79
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务