WeikangMa
V2EX  ›  问与答

mysql 给定条件索引如何建立?

  •  1
     
  •   WeikangMa · Apr 21, 2021 · 1086 views
    This topic created in 1865 days ago, the information mentioned may be changed or developed.
    表:id, 名称,注册时间,班级 ID, 年龄,性别,

    查询需求:

    id

    名字

    时间+名字

    班级+年龄

    班级+性别

    求问如何建立索引
    4 replies    2021-04-22 12:37:41 +08:00
    WeikangMa
        1
    WeikangMa  
    OP
       Apr 21, 2021
    个人认为

    名字: 最左原则, 单独加一个

    时间+名字: 时间区分度大, 名字可能是最左原则, 最好加一个时间_名字的联合索引

    年龄, 学生估计年龄前后差不了 5 岁, 性别区分度就更小了。 所以加一个班级的索引,或者班级+年龄的联合索引 都可以吧
    WeikangMa
        2
    WeikangMa  
    OP
       Apr 21, 2021
    你们平时会对 mysql 参数进行调优吗? 这特么不都是 dba 的事, 即使知道原理, 谁敢调呀。。。
    结果面试官评价一句: 数据库使用经验比较少。。。
    morty0
        3
    morty0  
       Apr 21, 2021
    考虑范围查询需求, 时间+名字, 年龄+班级
    GGGG430
        4
    GGGG430  
       Apr 22, 2021 via iPhone
    还是要看实际 sql 使用频率,高频率使用的优先建立,另外你说的这些有点纸上谈兵,最好是找一个 slave 实际去 explain 看看效果
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   1072 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 32ms · UTC 23:41 · PVG 07:41 · LAX 16:41 · JFK 19:41
    ♥ Do have faith in what you're doing.