为什么要避免 SELECT *

避免 SELECT * 是数据库开发中的一条重要原则,主要基于以下几个核心原因:


1. 性能浪费

  • 不必要的 I/O :读取不需要的列会增加磁盘 I/O,尤其当表包含大字段(如 TEXTBLOB、长字符串)时,代价巨大。
  • 内存与 CPU 开销:数据库需要将多余的数据加载到内存,并进行解析、传输,消耗更多 CPU 和内存资源。

2. 网络传输负担

  • 在客户端与数据库分离的场景(如应用程序服务器 + 数据库服务器),SELECT * 会传输大量无用数据,增加网络延迟,尤其在云环境或跨机房部署时影响显著。

3. 索引无法有效覆盖

  • 如果只需要少数几个字段,可以创建覆盖索引 ,直接通过索引返回数据(Using index),避免回表查询。
    使用 SELECT * 会强制回表,即使查询条件用到了索引,性能也会大打折扣。

4. 可读性与维护性差

  • 表结构变化引发隐患 :当表增加新列,SELECT * 会无差别返回所有列。如果应用代码未正确处理新增列(例如按位置取列值),可能导致程序异常或数据错乱。
  • 意图不清晰:阅读代码的人不知道实际需要哪些字段,增加维护难度。

5. 连接操作(JOIN)时的膨胀

  • 多表 JOIN 时使用 SELECT * 会返回所有参与表的全部列,极易产生重复列名(如 idname),并导致结果集行数不变但列数爆炸,浪费大量内存和网络资源。

✅ 正确做法

  • 只选择需要的列SELECT col1, col2 FROM table
  • 明确列名 :即使在 INSERT ... SELECT 或临时调试时也尽量列出字段
  • 利用工具/框架:ORM(如 MyBatis、Hibernate)中只映射必要字段

📌 唯一例外(可接受使用 SELECT *

  • 极低频率的临时查询 (手动 SELECT * 看一眼数据样本)
  • 已知表只有少数几列且未来不会变化(如配置表、字典表)
  • 使用 EXISTS 子查询时SELECT * 会被优化器忽略,写 SELECT 1 更规范)

💬 面试回答模板

"避免 SELECT * 主要是为了性能、网络和可维护性。它会额外读取不需要的列,增加磁盘 I/O 和网络传输;无法利用覆盖索引,容易导致回表;同时表结构变更时可能引发未知错误。最佳实践是始终显式列出所需字段。"

相关推荐
我是一颗柠檬5 小时前
【MySQL全面教学】MySQL性能优化实战Day13(2026年)
数据库·后端·sql·mysql·性能优化·database
weelinking7 小时前
【产品】11_实现后端接口——数据在背后如何流动
java·人工智能·python·sql·oracle·json·ai编程
zgl_200537797 小时前
源代码:跨数据库通用SQL语法解析与标注拆解
大数据·数据库·数据仓库·sql·etl·源代码管理
暴躁小师兄数据学院9 小时前
【AI大数据工程师特训笔记】第13讲:数据库性能手术刀
大数据·数据库·数据仓库·sql·postgresql
土狗TuGou11 小时前
SQL内功笔记 · 第2篇:列的约束
数据库·笔记·sql
Noushiki11 小时前
MySQL索引优化实战:高效查询的黄金法则
数据库·sql·mysql
土狗TuGou12 小时前
SQL内功笔记 · 第6篇:窗口函数的使用ROW_NUMBER等
java·数据库·后端·sql·mysql
网管NO.115 小时前
多表联查入门|INNER JOIN 内连接,关联查询基础(实操案例)
数据库·sql
土狗TuGou16 小时前
SQL内功笔记 · 第7篇:CTE&临时表&递归
数据库·笔记·后端·sql·mysql
土狗TuGou17 小时前
SQL内功笔记 · 第5篇:SQL逻辑执行顺序
数据库·笔记·后端·sql·mysql