php mysql select的时候*的效率问题
例如
我要查的表有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 * 肯定是影响效率的。
推荐阅读
-
php的慢速日志引起的Mysql错误问题分析
-
windows下配置apache+php+mysql时出现问题的处理方法
-
浅析php fwrite写入txt文件的时候用 不能换行的问题
-
2个自定义的PHP in_array 函数,解决大量数据判断in_array的效率问题
-
php使用mysqli和pdo扩展,测试对比mysql数据库的执行效率完整示例
-
php使用mysqli和pdo扩展,测试对比连接mysql数据库的效率完整示例
-
使用cmd运行mysql数据库的时候,报错:"不是内部命令也不是可有运行的程序"问题的解决办法
-
PHP使用curl_multi_select解决curl_multi网页假死问题的方法
-
PHP查询MySQL大量数据的时候内存占用分析
-
php的慢速日志引起的Mysql错误问题分析