Heim  >  Artikel  >  Backend-Entwicklung  >  php mysql select的时候*的效率问题

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

WBOY
WBOYOriginal
2016-06-06 20:07:211022Durchsuche

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

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn