php优化查询foreach代码实例讲解

admin3年前PHP教程27


php代码优化

应避免在php foreach里面进行sql查询
以下代码示例使用了laravel的操作数据库api,eloquent orm

foreach里面执行两次sql查询


// $datas 要返回的数据
foreach ($datas as $_v) {
  // todo 在foreach中查询了两次 **time**: 290 ms(postman)
  $uid = $_v->uid;
  $_v->user_name  = User::find($uid)->username; // 1
  $_v->user_avatar = User::find($uid)->avatar;  // 2
}

foreach里面执行一次sql查询


foreach ($datas as $_v) {
  // todo
  // 简单的优化使得两次sql查询变成一次
  // 在foreach中查询了一次 **time**: 230 ms(postman)
  $user = User::find($_v->uid));   // 1
  $_v->user_name  = $user->username;
  $_v->user_avatar = $user->avatar;
}


将sql查询移到foreach外面

上面两个方法都不可避免的在foreach里面执行了数据库查询
**应避免在foreach中执行sql查询**
此处我的做法是再加一层foreach+if来代替sql查询
// 本质上是将foreach中的查询移到外面
// $tmp_data_arr 是存储在foreach外面执行的数据库查询结果
foreach ($tmp_data_arr as $value) {
  foreach ($datas as $_v) {
    if ($_v->uid === $value['id']) { // **time**: 180 ms(postman)
      $_v->user_name  = $value['username'];
      $_v->user_avatar = $value['avatar'];
    }
  }
}

小结


// 返回数据
return $datas;

经过简单的优化:时间(ms):290 -> 230 -> 180

到此这篇关于php优化查询foreach代码实例讲解的文章就介绍到这了,更多相关php优化查询foreach内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

MacOS下PHP7.1升级到PHP7.4.15的方法

最近写SDK的时候需要用到object类型提示符,PHPStorm智能提示说需要PHP7.2以上才能支持这种类型提示。我一查我本机的PHP是7.1.30版本,于是考虑升级一下PHP版本。首先要尝试使用...

PHP加MySQL消息队列深入理解

消息队列:在消息的传输过程中保存消息的容器。消息队列管理器在将消息从它的源中继到它的目标时充当中间人。队列的主要目的是提供路由并保证消息的传递;如果发送消息时接收者不可用,消息队列会保留消息,直到可以...

如何正确选择高防IP呢?美国BGP高防物理机干嘛用的?

高防IP是什么?了解高防IP都可以给你防御一些什么东西?这一篇给你们深入科普以下高防IP到底是个什么东西?为什么高防IP理论上可以解决目前市面上所有的ddos攻击为什么高防IP对于ddos有效果?好了...

php是程序员吗(php转行可以做什么)

php是程序员吗狭义上说,PHP程序员便是用PHP做为开发语言的程序员。可是往往一个程序员不是只是限制某一种开发语言,或用某一种开发语言来划分的。可是为了提高开发功率,现在的科技企分工越来越清晰,很少...

Laravel统一封装接口返回状态实例讲解

前后端分离,接口返回封装方便你我他(方便前后端合作开发)在Laravel中可以在公共继承的Controller.php写方法进行调用返回app/Http/Controllers/Controller....

PHP队列场景以及实现代码实例详解

为了降低单点压力,通常会根据业务情况进行分表分库,将表分布在不同的库中(库可能分布在不同的机器上),但是一个业务场景可能会同时处理两个表的操作。在这种场景下,事务的提交会变得相对复杂,因为多个节点(库...