面试的时候遇到一道 mysql 的题,求解答

2021-08-04 20:06:45 +08:00
 irisShaw

面试官问,如果 mysql 中加了索引,并且强制让它走索引,最终没有走索引,如何排查。

我说了一些索引失效的场景,他说排除索引失效的情况,让我结合 mysql 元数据和执行计划是如何生成的进行回答,网上找了一些相关资料,但是并没有思路,所以在社区里求各位大神解答
1561 次点击
所在节点    问与答
13 条回复
tobias7
2021-08-04 20:27:39 +08:00
同等大神 回复
liprais
2021-08-04 20:30:22 +08:00
optimizer trace 看看就知道了
wenqiang1208
2021-08-04 20:39:56 +08:00
蹲一个
ylsc633
2021-08-04 20:48:07 +08:00
我试了下 数据就一千条

强制走索引 explain 一下

type = ALL

这种算一种 case 吧
SjwNo1
2021-08-04 20:51:49 +08:00
mysql server 有一套基于很多 magic number 的成本算法,可能是强行走索引成本预估更大吧。(猜的)
SjwNo1
2021-08-04 20:59:41 +08:00
如 2 楼所说,打开 optimizer_trace,看一下各种执行方式对应的成本
pt2021
2021-08-04 22:55:46 +08:00
答出来 MySQL 的成本计算这套呢,数据量少全表扫描更快,走索引会导致回表,这样呢
Kimen
2021-08-05 08:45:37 +08:00
搜了一圈没找到,蹲一个答案
NjcyNzMzNDQ3
2021-08-05 09:54:39 +08:00
说一个实际遇到关于类型导致不走索引的。

数据库内存时间戳,使用 char(13)。

不走索引:where = 1628128272000
走索引:where = ”1628128272000“

不知道这个作为答案行不行。
waitingChou
2021-08-05 11:17:10 +08:00
一个比较常见的情况是,mysql 判断走索引的成本太高,还不如扫全表。

一个典型的案例是,你的查询命中了索引 2/3 的数据, 如果走索引得先扫 2/3 的数据,然后这 2/3 的数据还得回表。相当于 扫了全表的 4/3 数据。

但我不太确定这会不会 导致 force index 语法也不生效
irisShaw
2021-08-05 19:59:23 +08:00
@NjcyNzMzNDQ3 这个是隐式类型转换,也是索引失效场景的一种,我说了,然后被面试官否定了,应该他想问的不是这种
54qyc
251 天前
index hints 不就是强制走索引吗?写了 hint 优化器还能无视 hint ?
54qyc
251 天前

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/793700

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX