php mysql select的时候*的效率问题
澳门新葡京官网
澳门新葡京官网
当前位置 : 澳门新葡京官网 > 新葡京娱乐场

php mysql select的时候*的效率问题

我想问下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 * 肯定是影响效率的。

栏目列表

广告位

澳门新葡京官网