Home >Backend Development >PHP Tutorial >php mysql select的时候*的效率问题
我想问下select的时候field为*和指定$field的时候效率对比大概是什么样的?
例如
我要查的表有10列 我实际需要里面8列的信息 那么 field * 和 field 指定 8列的效率相差大吗?
我想问下select的时候field为*和指定$field的时候效率对比大概是什么样的?
例如
我要查的表有10列 我实际需要里面8列的信息 那么 field * 和 field 指定 8列的效率相差大吗?
数据库的优化,select你所需要的字段,别看差不多,等到你数据量大的时候,这种优势就体现出来了
数据量大的时候,或者极限优化的情况下肯定是有差别的
个人的理解是在读取的过程中可能没有太多性能差别,但是读出来的数据是需要用的,数据传输的过程中,field *
出来的显然要比field
相应字段的要大,所以这时会产生效率差别。
建议用什么字段就select什么字段 我们要写最优的SQL
如果你的表字段不是特别多的话,效率上不会有什么明显的差别。
1、内存开销上:
假设当你的表的有100个字段的话,比如有一个字段是一篇5000字的文章text类型。
你select * from table limit 100这个时候查询会占用很多临时内存空间去完成你的请求。
2、传销效率上
并且,数据从MySQL服务器传输到你的客户端,也会花更多的时间传输。
3、安全问题
如果你的表上面有敏感的字段,比如用户隐私的性别,金钱数,当你select *时,而上层逻辑在这里又有漏洞,就有可能会暴露。
4、代码实践
当你修改表字段名称a改成b后,select * 语句执行不会有问题,但是你的代码里取数据时,可能会有隐藏的问题。
因为你之前本意是select a,现在变成select b,而你上层逻辑之前取得是a。
用什么 查什么 select * 肯定是影响效率的。