SQL基础查询怎么写_重要技巧总结提升查询效率【技巧】

2次阅读

sql查询执行顺序为FROM→WHERE→GROUP BY→HAVING→select→ORDER BY→LIMIT;LEFT JOIN右表过滤须写在ON而非WHERE;避免SELECT*;LIKE查询慎用前导通配符;ORDER BY字段需建索引,深分页宜用游标。

SQL基础查询怎么写_重要技巧总结提升查询效率【技巧】

SQL基础查询写法其实不难,关键在理解逻辑顺序和避开常见坑。SELECT、FROM、WHERE、ORDER BY 这几个子句的执行顺序不是从左到右,而是 FROM → WHERE → GROUP BY → HAVING → SELECT → ORDER BY → LIMIT。写错顺序或滥用字段,很容易查得慢、结果错、甚至报错。

WHERE 条件要写在 JOIN 之后,但别在 WHERE 里过滤 LEFT JOIN 的右表字段

很多人习惯把所有条件都塞进 WHERE,但对 LEFT JOIN 来说,这会把本该保留的 NULL 行给过滤掉,实际变成 INNER JOIN。

  • ✅ 正确:右表过滤条件写在 ON 后面
  • ❌ 错误:LEFT JOIN 后在 WHERE 中写 t2.status = ‘active’
  • 示例:SELECT u.name, o.amount FROM users u LEFT JOIN orders o ON u.id = o.user_id AND o.status = ‘paid’

避免 SELECT *,只取真正需要的字段

查全字段不仅传输数据多、内存占用高,还可能让数据库无法走覆盖索引(Covering Index),导致额外回表。

  • 能写具体字段就别用 *
  • 尤其在大表 JOIN 或分页场景下,影响明显
  • 如果只要计数,直接用 count(1) 或 COUNT(*),别 SELECT * 再用程序数

LIKE 查询注意前导通配符,不然索引失效

WHERE name LIKE ‘%abc’ 无法使用索引;WHERE name LIKE ‘abc%’ 才可以。

SQL基础查询怎么写_重要技巧总结提升查询效率【技巧】

Kreado AI

Kreado ai是一个多语言AI视频创作平台,只需输入文本或关键词,即可创作真实/虚拟人物的多语言口播视频。 为创作者提供AI赋能

SQL基础查询怎么写_重要技巧总结提升查询效率【技巧】 182

查看详情 SQL基础查询怎么写_重要技巧总结提升查询效率【技巧】

  • 模糊查开头:用 ‘abc%’ —— 能走索引
  • 模糊查中间或结尾:考虑加全文索引、或者用 etl 预处理字段(如倒序存 name_rev)
  • 大小写敏感问题?可用 LOWER(name) LIKE LOWER(‘ABC%’),但注意函数会让索引失效,建议字段统一小写存储 + 建函数索引(如 postgresql 支持)

ORDER BY + LIMIT 配合 WHERE 时,确保排序字段有索引

比如查“最新10条订单”,写成 SELECT * FROM orders WHERE status=’paid’ ORDER BY created_at DESC LIMIT 10,如果 created_at 没索引,就得全表扫描再排序。

  • 复合索引更优:INDEX(status, created_at) 可同时加速 WHERE 和 ORDER BY
  • 注意 ASC/DESC 顺序,mysql 8.0+ 支持混合方向索引,老版本建议统一升序
  • 分页深翻(OFFSET 大)性能差?改用游标分页(记录上一页最大ID)

基本上就这些。基础查询写对不难,但细节决定效率和稳定性。多看执行计划(EXPLAIN),少凭感觉优化。

text=ZqhQzanResources