SQL中如何处理多维数据的查询:复合索引与SELECT编写
复合索引应按等值查询字段(高频优先)、范围查询字段(仅一个)、ORDER BY字段(方向一致)顺序建立;SELECT *会强制回表降低性能;OR条件易使索引失效,宜改写为UNION;分区表中分区键应置于复合索引最左列。复合索引该按什么顺序建?顺序直接决定查询能否命中索引——MySQL/PostgreSQL 的 B-Tree 索引是左前缀匹配的,WHERE a = 1 AND b = 2 AND c > 3 能用上 (a, b, c),但换作 (b, a, c) 就只能用上第一个字段 b(如果没其他条件),a 和 c 就失效了。实操建议:把等值查询字段(=、IN)放最左边,且高频字段优先范围查询字段(>、BETWEEN、LIKE 'abc%')紧接其后,且只能有一个——再往后字段无法被索引利用ORDER BY 字段可追加在末尾,但仅当排序方向一致(全 ASC 或全 DESC)且无混合时才有效避免把 SELECT 中的计算字段(如 UPPER(name))或函数结果作为索引首列,否则无法走索引SELECT * 会拖垮多维查询性能吗?会,尤其在宽表+复合索引场景下。索引本身可能覆盖查询(Covering Index),但 SELECT * 强制回表——即使所有 WHERE 条件都命中索引,仍要根据主键去聚簇索引捞出所有字段,IO 成倍增加。实操建议:只查真正需要的字段,比如 SELECT user_id, status, created_at,而非 SELECT *若常查固定几列,考虑把它们全包含进复合索引末尾(叫“索引覆盖”),例如索引 (tenant_id, status, created_at, user_id) 可让 SELECT user_id, created_at FROM t WHERE tenant_id = ? AND status = ? 完全免回表注意大字段(TEXT、JSON、长 VARCHAR)哪怕没选,只要在表结构里,回表时仍要读取整行,影响依然存在WHERE 中用了 OR,复合索引还有效吗?大概率失效。比如 WHERE a = 1 OR b = 2,即使有 (a, b) 索引,优化器通常放弃走索引,改用全表扫描——因为 OR 拆解后是两个独立范围,B-Tree 不支持高效合并。 ARTi.PiCS ARTi.PiCS是一款由AI驱动的虚拟头像生产器,可以生成200多个不同风格的酷炫虚拟头像
