得物Java秋招一面
刚面试完,趁着还记得住赶紧来分享一下
是一位比较和善的面试官(浓重的黑眼圈,疲惫的神态,得物强度确实可见一斑),但是技术真的很强,不是背背常规八股就能应对的
面试时间非常紧凑,每个人只有30-40min,所以面试官开头直接说今天不问项目相关的,只考察下基础(然后就是对MySQL半个小时的拷打):
- 介绍下InnoDb索引结构和分类吧(常规八股,直接吟唱,此时的我还没有意识到危险)
- 什么是联合索引的最左前缀匹配原则?
- 比如创建了A,B,C的联合索引,它的索引树结构是怎样的?如果我的条件语句是"A >= 0 AND B = 7",此时联合索引能命中吗,InnoDb查询流程是怎样的?
- 听说过"索引下推"这种优化方式吗,方式是怎样的?
- InnoDb可重复读隔离解决了哪些问题?什么是幻读?
- 如果A是主键,查询语句是"A=0",此时加的是record锁还是next-key锁?如果A不是主键而是非唯一索引呢?
- 如果A是非唯一索引,表里只有"A=1"和"A=10"两条数据,此时有两条命令:"SELECT * FROM ... WHERE A=5 FOR UPDATE";"SELECT * FROM ... WHERE A=6 FOR UPDATE"。请问这两条命令会互斥吗,什么时候互斥、什么时候不互斥?
- 介绍一下binlog、redolog、undolog以及它们的使用场景,binlog有哪几种形式,优缺点各是什么?
手撕代码:
Leetcode 131 分割回文串,中等题只给10分钟时间,勉强写完代码,面试官说思路没问题,也许有些边界条件需要再看看,没让跑用例(可能赶时间面下一场,得物真是压榨人啊)
反问:
- 得物工作强度(其实黑眼圈已经说明一切了,只是没想好问啥就随便问了)
- MySQL的问题都很深入,请问平时是如何学习这些知识,为何能掌握这么深(广度靠看书,深度靠看技术博客)
9.9更新
上午把这些知识点深入了解了一遍,感觉掌握的差不多了,如果大家对上述问题有疑问我可以帮忙解答
9.12更新
今天发现流程已终止,意料之中哈哈哈。但是很感谢这次面试,今天面携程的时候也问了类似的问题,我已经可以对答如流
#得物校招求职汇总##秋招#