MySQL中WHERE多字段AND查询需按最左前缀原则建索引:等值字段(=、IN)放前,至多一个范围字段(>、BETWEEN、LIKE 'abc%')放末尾,ORDER BY字段可追加索引末尾以避免排序;OR条件优先改写为UNION,IN视为等值不影响索引;EXPLAIN需重点观察type、rows和Extra字段验证实际索引使用效果。WHERE 中多个字段同时查,索引怎么建才生效MySQL 的 WHERE 条件里用 AND 连多个字段时,只有按「最左前缀」顺序命中索引列,才能走索引。比如查 WHERE status = ? AND category = ? AND created_at > ?,但只给 (category, status) 建索引,status 就用不上——它不在索引最左边。索引列顺序必须覆盖查询中「连续且从左开始」的条件字段等值查询(=、IN)字段放前面,范围查询(>、BETWEEN、LIKE 'abc%')放后面,且只能有一个范围字段在末尾如果还有 ORDER BY 或 GROUP BY,尽量把排序字段也塞进索引尾巴,避免额外排序LIKE 模糊搜索还能用组合索引吗能,但仅限前缀匹配:LIKE 'abc%' 可走索引;LIKE '%abc' 或 LIKE '%abc%' 一定不走,无论索引怎么建。如果查询是 WHERE name LIKE 'John%' AND dept = 'tech',索引应为 (dept, name) 或 (name, dept),但前者更优——因为 dept 是等值,name 是范围,符合“等值+范围”结构别指望 fulltext 或 LIKE 配合组合索引解决全文模糊,那是 FULLTEXT 索引或 ES 的事COLLATION 要和查询一致,比如字段是 utf8mb4_0900_as_cs,但查询用默认校对规则,可能导致索引失效有 OR 条件时组合索引还管用吗基本不管用。WHERE a = 1 OR b = 2 即使 a 和 b 各自都有单列索引,优化器大概率会放弃索引走全表扫描——MySQL 对 OR 的索引合并(index merge)支持弱,且代价高。 Cleanup.pictures 智能移除图片中的物体、文本、污迹、人物或任何不想要的东西
mysql多字段搜索如何设计组合索引_mysql索引查询加速