为什么要避免 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 和网络传输;无法利用覆盖索引,容易导致回表;同时表结构变更时可能引发未知错误。最佳实践是始终显式列出所需字段。"

相关推荐
格鸰爱童话8 小时前
跟着AI学sql
数据库·sql
数厘9 小时前
2.13 sql数据更新(UPDATE)
数据库·sql·oracle
℡終嚸♂6809 小时前
SQL 注入与 ThinkPHP 漏洞技术讲义
数据库·sql
不剪发的Tony老师1 天前
Noir:一款键盘驱动的现代化数据库管理工具
数据库·sql
光泽雨1 天前
UNION 和 UNION ALL 作用
数据库·sql
heimeiyingwang1 天前
【架构实战】SQL调优实战:从执行计划到索引优化
数据库·sql·架构
XDHCOM1 天前
ORA-06521: PL/SQL映射函数错误,权威解析Oracle报错故障修复与远程处理方案
数据库·sql·oracle
数厘1 天前
2.11 约束的使用(主键、外键、非空、唯一、默认值约束)
sql·mysql·数据分析
大大大大晴天️1 天前
Flink技术实践-Flink SQL 开发中的隐蔽陷阱
大数据·sql·flink