<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多个不同风格的酷炫虚拟头像
相关推荐
Wang ruoxi1 小时前
Pygame 小游戏——贪吃蛇大数据魔法师5 小时前
Streamlit(二十三)- 教程(二)- 动态导航AI人工智能+电脑小能手8 小时前
【大白话说Java面试题 第87题】【Mysql篇】第17题:分布式事务的实现原理?yyuuuzz8 小时前
独立站的技术基础与常见运维问题心中有国也有家8 小时前
GE图引擎深度解析——CANN的计算图优化与执行引擎卷毛的技术笔记9 小时前
告别硬编码!Spring AI Alibaba 实现 AI Agent 智能工具调用(Tool Calling)编程大师哥9 小时前
匿名函数 lambda + 高阶函数vb2008119 小时前
FastAPI APIRouteradrninistrat0r10 小时前
Java调用链MCP分析工具杨充10 小时前
1.3 浮点型数据设计灵魂