SQL在JOIN语句中过滤非必要字段_减少传输开销与查询执行时间

应只SELECT必要字段、WHERE条件勿误放ON中、用覆盖索引避免回表、小表驱动大表且驱动表需有索引。SELECT 中只写真正需要的字段,别用 *用 * 看起来省事,但数据库得把整行所有字段从磁盘读出来、经过网络传给客户端、再被应用层丢弃掉------这些字段哪怕你压根没用,也全程参与了 I/O、内存、网络开销。尤其当表里有 TEXT、JSON、BLOB 或宽字段(比如 50 列)时,性能下降会非常明显。实操建议:JOIN 前先列清楚业务逻辑真正要什么:是只需要 user.id 和 order.total?那就只 SELECT 这两个如果用 ORM,确认它生成的 SQL 没偷偷加 * 或冗余字段(比如 Django 的 .values() / .only() 要显式指定)对宽表 JOIN,宁可多写几遍字段名,也别依赖 SELECT * ------ 后续加字段时,* 会无声无息拖慢查询WHERE 条件写在 JOIN 后,别错放到 ON 里过滤主表ON 是定义关联逻辑的,WHERE 才是最终筛选结果的。把本该在 WHERE 的条件(比如 user.status = 'active')误塞进 ON,会导致 LEFT JOIN 变成隐式 INNER JOIN,或漏掉本该保留的左表记录------这不是字段多不多的问题,是逻辑错误。常见错误现象:LEFT JOIN users u ON u.id = o.user_id AND u.status = 'active' → 如果用户 status 不是 active,这条 user 记录就"消失"了,哪怕你只想查订单,也拿不到对应用户信息正确做法是:LEFT JOIN users u ON u.id = o.user_id WHERE u.status = 'active'(注意:这会让 LEFT JOIN 失效,等价于 INNER;若真要保留左表空值,WHERE 应写成 WHERE (u.status = 'active' OR u.status IS NULL))用覆盖索引避免回表,让 SELECT 字段全落在索引里如果 SELECT 的字段都能被某个索引"覆盖",MySQL/PostgreSQL 就不用回主键索引捞数据------直接从二级索引里读完走人。这对 JOIN 尤其关键:每多一次回表,就是多一次随机 I/O。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。

相关推荐
曹牧4 小时前
Oracle:前缀匹配之REGEXP_LIKE
数据库·oracle
Unbelievabletobe4 小时前
解决了股票api接口盘后数据更新慢的问题
大数据·开发语言·python
lpd_lt6 小时前
AI Coding的常用Prompt技巧
python·ai·ai编程
小江的记录本6 小时前
【JVM虚拟机】堆内存分代模型:年轻代(Eden+Survivor)、老年代、元空间Metaspace(附《思维导图》+《面试高频考点清单》)
java·前端·jvm·后端·python·spring·面试
在繁华处6 小时前
Java从零到熟练(三):流程控制
java·开发语言·python
asdzx676 小时前
使用 Python 快速提取 PDF 中的表格
python·pdf
无情的西瓜皮7 小时前
MCP协议实战:用Python从零搭建一个AI Agent工具服务器(保姆级教程)
服务器·人工智能·python·mcp
暴躁小师兄数据学院7 小时前
【AI大数据工程师特训笔记】第05讲:关联查询
数据库·sql·oracle
倔强的石头_7 小时前
《Kingbase护城河》——跨平台环境下的数据库联调实战
数据库
lzhdim7 小时前
SQL 入门 17:MySQL 数据类型:从字符串到 JSON 的全面解析
数据库·sql·mysql·json