WHERE a = ? AND b = ? 用不上 (a, b) 索引是因为未满足最左前缀匹配原则:必须从索引最左列开始连续使用,且首列需为确定等值条件;若跳过a直接查b,或a为范围/函数/NULL,则索引失效。为什么 WHERE a = ? AND b = ? 用不上 (a, b) 索引?不是索引建错了,是查询条件没触发最左前缀匹配。MySQL 多列索引生效前提是:从左到右连续使用索引列,中间不能跳过。比如索引是 (status, created_at, user_id),但查询只写了 WHERE user_id = 123,那整个索引就失效。常见错误现象:EXPLAIN 显示 type: ALL 或 key: NULL,哪怕字段上明明建了索引。必须保证 WHERE 条件中,最左边的列(如 status)有确定值(非 IS NULL、非范围、非函数包裹),后续列才能被索引下推范围查询(>、BETWEEN、LIKE 'abc%')会截断索引,WHERE status = 'active' AND created_at > '2024-01-01' AND user_id = 123 实际只用到前两列OR 条件大概率让整条索引失效,别指望优化器能聪明地拆解区分度低的字段(如 gender、is_deleted)该不该放索引最左?不该------除非它能显著过滤数据。区分度(cardinality)低于 5% 的字段,单独建索引几乎没意义;放在联合索引最左,反而拖慢所有依赖该索引的等值查询。使用场景:你有一张订单表,order_status 只有 4 个值(pending / paid / shipped / cancelled),但 user_id 有百万级唯一值。此时 (order_status, user_id) 不如 (user_id, order_status)。用 SHOW INDEX FROM table_name 查看 Cardinality 列,对比字段实际唯一值数量执行 SELECT COUNT(DISTINCT col) / COUNT(*) FROM table_name,结果低于 0.03 就算低区分度如果必须查低区分度字段,优先考虑加在索引右侧,作为"筛选后排序/分组"的辅助列如何验证新索引是否真被用了?别只信 EXPLAINEXPLAIN 显示 key 非空,不代表查询真的快------可能走了索引但回表太多,或者扫描了大量无效索引页。 稿定AI 拥有线稿上色优化、图片重绘、人物姿势检测、涂鸦完善等功能
相关推荐
老毛肚4 小时前
jeecg-boot-base-core 02 dayyaoxin5211234 小时前
434. Java 日期时间 API - Period 基于日期的时间段岁月宁静5 小时前
RAG 文档摄入全链路,从原理到生产落地火山上的企鹅5 小时前
Codex实战:APP远程升级服务搭建(三)后台管理页面(APK 上传、版本管理、多应用页签)程序员二叉5 小时前
【JUC】线程池全套深度详解|参数|流程|拒绝策略|调优|异常处理JaydenAI5 小时前
[对比学习LangChain和MAF-07]如何引入人机交互的审批流程阿狸猿6 小时前
论 NoSQL 数据库技术及其应用神奇元创6 小时前
商用级光路加速卡:大模型推理的极速落地方案FBI HackerHarry浩6 小时前
DataGrip2023.2.3默认保存的数据库和.sql文件在哪里?怎么修改默认路径?袁小皮皮不皮6 小时前
3.HCIP OSPF补充知识(优化版)