V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
irisShaw
V2EX  ›  问与答

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

  •  1
     
  •   irisShaw · Aug 4, 2021 · 2390 views
    This topic created in 1739 days ago, the information mentioned may be changed or developed.

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

    我说了一些索引失效的场景,他说排除索引失效的情况,让我结合 mysql 元数据和执行计划是如何生成的进行回答,网上找了一些相关资料,但是并没有思路,所以在社区里求各位大神解答
    
    13 replies    2023-08-25 16:19:42 +08:00
    tobias7
        1
    tobias7  
       Aug 4, 2021
    同等大神 回复
    F281M6Dh8DXpD1g2
        2
    F281M6Dh8DXpD1g2  
       Aug 4, 2021 via iPhone
    optimizer trace 看看就知道了
    wenqiang1208
        3
    wenqiang1208  
       Aug 4, 2021
    蹲一个
    ylsc633
        4
    ylsc633  
       Aug 4, 2021   ❤️ 1
    我试了下 数据就一千条

    强制走索引 explain 一下

    type = ALL

    这种算一种 case 吧
    SjwNo1
        5
    SjwNo1  
       Aug 4, 2021
    mysql server 有一套基于很多 magic number 的成本算法,可能是强行走索引成本预估更大吧。(猜的)
    SjwNo1
        6
    SjwNo1  
       Aug 4, 2021
    如 2 楼所说,打开 optimizer_trace,看一下各种执行方式对应的成本
    pt2021
        7
    pt2021  
       Aug 4, 2021
    答出来 MySQL 的成本计算这套呢,数据量少全表扫描更快,走索引会导致回表,这样呢
    Kimen
        8
    Kimen  
       Aug 5, 2021
    搜了一圈没找到,蹲一个答案
    NjcyNzMzNDQ3
        9
    NjcyNzMzNDQ3  
       Aug 5, 2021
    说一个实际遇到关于类型导致不走索引的。

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

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

    不知道这个作为答案行不行。
    waitingChou
        10
    waitingChou  
       Aug 5, 2021
    一个比较常见的情况是,mysql 判断走索引的成本太高,还不如扫全表。

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

    但我不太确定这会不会 导致 force index 语法也不生效
    irisShaw
        11
    irisShaw  
    OP
       Aug 5, 2021
    @NjcyNzMzNDQ3 这个是隐式类型转换,也是索引失效场景的一种,我说了,然后被面试官否定了,应该他想问的不是这种
    54qyc
        12
    54qyc  
       Aug 25, 2023
    index hints 不就是强制走索引吗?写了 hint 优化器还能无视 hint ?
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2978 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 55ms · UTC 07:08 · PVG 15:08 · LAX 00:08 · JFK 03:08
    ♥ Do have faith in what you're doing.