<p>SELECT * 不一定比写全字段慢,但更危险------它掩盖性能问题、阻碍覆盖索引、增大反序列化压力、引发字段冲突与预编译失败,仅限调试或极小元数据表使用。</p>SELECT * 真的比写全字段慢吗?不一定,但绝大多数情况下它更危险------不是因为"多传几个字节"拖慢了网络,而是因为它掩盖了真实性能问题,且在多数场景下反而触发更多开销。你测出 SELECT * 比 SELECT col1, col2 快,很可能是因为:查询结果集小、字段少、缓存命中高,或者 MySQL 优化器对 * 做了简单路径优化(比如跳过列解析)。但这不具普适性,尤其当表有 TEXT/BLOB 字段、大量冗余列、或走覆盖索引时,SELECT * 就会暴露代价。一旦表结构变更(比如新增一个 10MB 的 json_log 字段),SELECT * 查询立刻变卡,而明确列出字段的语句完全不受影响无法利用覆盖索引:如果只查 id 和 name,而这两个字段都在联合索引里,MySQL 可以不回表;但 SELECT * 强制回表读取所有列,哪怕其他列根本用不到应用层反序列化压力增大:ORM 或 JSON 序列化时,多加载几十个 NULL 或空字符串字段,GC 和内存分配频率明显上升EXPLAIN 能看出 SELECT * 的隐患吗?能,但要看清关键字段,不能只扫一眼 type 是不是 ALL。执行 EXPLAIN SELECT * FROM users WHERE status = 1 后,重点关注:key_len、Extra、rows 这三列。key_len 显示实际用到的索引字节数;如果索引包含 (status, name, email),但 SELECT * 导致 key_len 比 SELECT status, name 小,说明没走覆盖索引Extra 出现 Using filesort 或 Using temporary 时,SELECT * 往往加剧排序/临时表开销,因为要搬运更多数据rows 数值偏大 + type 是 index 或 ALL,基本可判定是全索引扫描或全表扫描------这时 SELECT * 和显式列的物理 I/O 差距就拉开了什么时候可以勉强用 SELECT *?仅限于开发调试、临时脚本、或极小数据量的元数据表(比如配置表 sys_config 不超过 100 行)。 ARTi.PiCS ARTi.PiCS是一款由AI驱动的虚拟头像生产器,可以生成200多个不同风格的酷炫虚拟头像
相关推荐
李白客16 小时前
MySQL迁移操作手册:一次完整迁移的实战路径new【一个】对象16 小时前
登录与注册完整流程分析仙俊红16 小时前
线程池面试晴天¥16 小时前
Oracle 19c RAC修改监听默认端口皮卡祺q16 小时前
【redis1】基本指令,五大数据类型,存储优化,使用场景】SilentSamsara16 小时前
爬虫工程化:Playwright + 反反爬 + 数据清洗管道实战AI玫瑰助手16 小时前
Python函数:函数的返回值(return)与多值返回花果山~~程序猿16 小时前
快速认识python项目的虚拟环境杜子不疼.16 小时前
Agent Skills 的演进治理与 Swarm Skills 自演进wanghowie17 小时前
26.v3 核心升级:语义层 + 指标体系——禁止 LLM 直连 SQL