select 某些字段比select * 更快

文章指出避免使用`SELECT *`,因为它可能导致性能问题,尤其是在存在覆盖索引的情况下。覆盖索引允许MySQL直接从索引中获取查询所需的数据,而无需读取数据文件,从而提高查询速度。当查询涉及大量行和包含长文本字段时,不读取数据的性能优势更加显著。此外,`SELECT *`还会影响SQL优化器的决策,增加网络传输和内存CPU消耗。

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

1 尽量养成不要使用*的习惯,select * 可能会对性能产生严重影响,
有一种索引,叫做覆盖索引。准确来说它不是一种索引方式,而是一种索引覆盖查询列程度。比如有一个常用查询,只需要用到表中的某两列,user_id和post_id,而且有一个多列索引已经覆盖了这两个列,那么这个索引就是这个查询的覆盖索引了。
如果select `user_id`,`post_id` from xxx 的话,mysql是可以不用读data,直接使用index里面的值就返回结果的。但是一旦用了select*,就会有其他列需要读取,这时在读完index以后还需要去读data才会返回结果。这两种处理方式性能差异非常大,特别是返回行数比较多,并且读数据需要IO的时候,可能会有几十上百倍的差异。
在EXPLAIN一个语句的时候,有一个信息叫做,Extra,第一种情况,不读data的时候,这个信息是Using index。第二个是Using where。

2 sql的执行过程是(不考虑查询缓存 )
解析器 -----》 预处理器 -----》 优化器 -----》 查询执行引擎 -----》 存储引擎

1)select * 会让优化器无法使用上面描述的覆盖索引这类优化。
2)网络开销,如果db和应用程序不在同一台机器,这种开销非常明显
3)额外的io,内存和cpu的消耗,因为多取了不必要的列。

影响 ,当列比较多,尤其列里面有长的文本字段,影响越明显。

详细可见:MySQL覆盖索引和优化

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值