mysql explain中的 “Select tables optimized away”

本文探讨了在MySQL中使用EXPLAIN时遇到的Selecttables Optimized Away提示,解释了这一现象背后的原因,即MySQL能够直接从表内部读取结果,无需执行实际的SELECT操作,从而实现SQL语句的极致优化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天在做SQL语句优化的时候,在explain的时候,有这样一个提示:

EXPLAIN   SELECT MAX(`year`) FROM st_sch_recruit_info info

输出的结果里,Extra列输出了"Select tables optimized away"语句。

这个在MySQL的手册里面没有任何提及,不过看其他各列的数据大概能猜到意思:SELECT操作已经优化到不能再优化了(MySQL根本没有遍历表或索引就返回数据了)。

在MySQL官方站点翻到两段相关的描述,印证了上述观点,原文如下:
For explains on simple count queries (i.e. explain select count(*) from people) the extra section will read "Select tables optimized away." This is due to the fact that MySQL can read the result directly from the table internals and therefore does not need to perform the select.


官方地址如下:
http://mysql2.mirrors-r-us.net/doc/refman/5.0/en/explain.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值