mysql经典问题(可用于面试提问)

mysql经典问题(可用于面试提问)

1.Where 后面的列顺序是不是要符合最左原则?

Where a=1 and b=2 等价于 Where b=2 and a=1

最左原则指的是索引顺序,不是谓词顺序,以上两个条件都匹配(a,b) 复合索引。

2.Join 的顺序是否指定左边为驱动表?

Inner Join场景下,在执行计划中按统计信息的预估自动选中驱动表,Left Join ,Right Join 时左右写的顺序才有显式意义。

3.业务上有随机返回的需求,能否用order by rand()

一般不建议,如果结果集非常小,勉强可用,但结果集大时由于随机数排序,会产生Sort操作甚至溢出到磁盘,有很大性能损耗,此类需求可以考虑伪随机算法。

4.Delete数据之后,为什么磁盘空间占用反而大了?

Delete数据并不能清理数据文件空间,反而会导致Undo,Binlog文件的增长,使用Optimize收缩。

5.Binlog是否一定要Row格式?

在主从场景下,Binlog使用Row格式是为了保证主从数据一致性。

单机场景下,Binlog做为增长数据备份使用,同时也包括一些语句级数据恢复的功能。

6.死锁、阻塞的区别

通常说的阻塞,主要是由于锁获取不到,产生的请求被阻塞,一般需要手动解锁(Kill或等待)。

死锁不等于阻塞,虽然死锁中阻塞是必现的,但是会自动回滚事务解锁,不用手动处理,但需要业务判断语句逻辑。

以上两种情况都是由于业务侧逻辑出现,并非内核原因。

7.做DDL时是否会锁表

所有的DDL都需要锁表,只是操作顺序和操作获取时间的问题。如下图所示,允许并发DDL是No,就证明对业务有一些阻塞。

相关推荐
岁岁种桃花儿1 小时前
MySQL从入门到精通系列:InnoDB记录存储结构
数据库·mysql
芝士爱知识a2 小时前
2026年AI面试软件推荐
人工智能·面试·职场和发展·大模型·ai教育·考公·智蛙面试
jiunian_cn3 小时前
【Redis】hash数据类型相关指令
数据库·redis·哈希算法
石去皿3 小时前
大模型面试通关指南:28道高频考题深度解析与实战要点
人工智能·python·面试·职场和发展
冉冰学姐3 小时前
SSM在线影评网站平台82ap4(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm框架·在线影评平台·影片分类
C雨后彩虹3 小时前
CAS与其他并发方案的对比及面试常见问题
java·面试·cas·同步·异步·
美团程序员3 小时前
80道经典常见测试面试题
软件测试·面试·职场和发展·软件测试面试
测试秃头怪3 小时前
面试大厂就靠这份软件测试八股文了【含答案】
自动化测试·软件测试·python·功能测试·面试·职场和发展·单元测试
测试杂货铺3 小时前
软件测试面试题大全,你要的都在这。。
自动化测试·软件测试·python·功能测试·面试·职场和发展·测试用例
职豚求职小程序3 小时前
校园招聘——荣耀2025秋招,有哪些值得注意的信息?(含荣耀笔面试攻略)
面试·职场和发展