索引是否有效取决于Cardinality值高低:接近总行数(≥95%)说明区分度高,适合建索引;<10%则单列索引意义不大;低区分度字段应置于联合索引后缀,如(created_at, status),并用EXPLAIN验证实际使用情况。索引有没有用,先看 Cardinality 值够不够高MySQL 的 SHOW INDEX FROM table_name 里那个 Cardinality 字段,不是"有多少行",而是"该列值大概有多少个不同取值"。它直接影响优化器是否愿意走索引。如果 Cardinality 只有几百,而表有百万行,那这个索引大概率被忽略------因为扫描索引再回表,比直接全表扫还慢。Cardinality 接近表总行数(比如 95% 以上),说明这列区分度高,适合建索引如果 Cardinality 小于总行数的 10%,基本可以判定:加单列索引意义不大注意:Cardinality 是采样估算值,执行 ANALYZE TABLE table_name 可刷新,但不会实时更新区分度低的字段硬加索引,反而拖慢写入比如 status 只有 'active'、'inactive'、'pending' 三个值,就算加上索引,查询时优化器大概率走全表扫描;更麻烦的是,每次 INSERT/UPDATE 都要维护这个索引 B+ 树,写放大明显。常见陷阱:给布尔型、枚举型、状态码字段单独建索引,却不结合查询条件中的其他过滤字段替代方案:把低区分度字段放在联合索引的**后缀位置**,比如 (created_at, status),靠前缀 created_at 拉高整体选择性验证方法:用 EXPLAIN 看 type 是否为 ref 或 range,而不是 ALL联合索引的顺序怎么排?看 WHERE 条件里的等值匹配和范围查询索引生效不只看有没有,更看字段在 WHERE 中的使用方式。MySQL 只能高效利用索引的最左前缀,一旦遇到范围查询(>、BETWEEN、LIKE 'abc%'),后面的字段就失效了。 文小言 百度旗下新搜索智能助手,有问题,问小言。
相关推荐
m0_514520572 小时前
SQL在SQL存储过程中优化子查询_缓存中间结果减少开销21439652 小时前
JavaScript中剩余参数在函数签名中的定义位置与限制2301_815279523 小时前
CSS定位如何实现多行文字垂直居中_通过绝对定位模拟表格m0_684501983 小时前
C#怎么使用LINQ Contains包含判断 C#如何用Contains实现类似SQL IN查询的集合包含判断【语法】程序媛徐师姐3 小时前
Python基于深度学习的手写输入识别系统【附源码、文档说明】2301_764150563 小时前
c++如何读取和解析带BOM头的UTF-8与UTF-16文本流【详解】qq_424098563 小时前
HTML函数开发用窄边框笔记本有优势吗_便携与性能权衡【指南】Wyz201210243 小时前
CSS如何实现导航栏下划线随鼠标移动_利用-hover伪类与过渡动画控制2201_761040593 小时前
SQL如何统计每个用户的首次行为时间_MIN聚合与分组