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

 更新时间:2021年03月22日 09:10:22   投稿:newname  
这篇文章主要介绍了php优化查询foreach代码实例讲解,列举了代码实例和测试结果,有感兴趣的同学可以学习下

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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Yii2选项卡的简单使用

    Yii2选项卡的简单使用

    这篇文章主要为大家详细介绍了Yii2选项卡的简单使用,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05
  • YII Framework框架教程之缓存用法详解

    YII Framework框架教程之缓存用法详解

    这篇文章主要介绍了YII Framework框架教程之缓存用法,结合实例形式详细分析了Yii框架缓存的结构,原理,使用方法与相关注意事项,需要的朋友可以参考下
    2016-03-03
  • php命令行写shell实例详解

    php命令行写shell实例详解

    这篇文章通过实例给大家介绍了php命令行写shell的方法,代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧
    2018-07-07
  • php实现window平台的checkdnsrr函数

    php实现window平台的checkdnsrr函数

    这篇文章主要介绍了php实现window平台的checkdnsrr函数,PHP的自带checkdnsrr函数只在linux平台有效,本文就模拟出了一个window下可以使用的checkdnsrr函数,需要的朋友可以参考下
    2015-05-05
  • php 无限级数据JSON格式及JS解析

    php 无限级数据JSON格式及JS解析

    公司要做个Flash效果的页面,需要个无限级树,显示用户邀请的好友及其下线,由此就构成了无限级的关系,可能下线有无限多。
    2010-07-07
  • Laravel框架实现的rbac权限管理操作示例

    Laravel框架实现的rbac权限管理操作示例

    这篇文章主要介绍了Laravel框架实现的rbac权限管理操作,结合实例形式分析了Laravel框架权限控制rbac相关数据库创建、读写及权限判断等操作技巧,需要的朋友可以参考下
    2019-01-01
  • 如何利用http协议发布博客园博文评论

    如何利用http协议发布博客园博文评论

    这篇文章主要介绍了利用http协议发布博客园博文评论的方法,首先,大家要明确给博文提交评论的实质就是通过http协议服务器发送一个post请求,需要的朋友可以参考下
    2015-08-08
  • php中PDO方式实现数据库的增删改查

    php中PDO方式实现数据库的增删改查

    PDO是mysql数据库操作的一个公用类了,我们不需要进行自定类就可以直接使用pdo来操作数据库了,但是在php默认配置中pdo是未开启所以我们必须先在php.ini中开启它才可以使用。
    2015-05-05
  • TP5(thinkPHP框架)实现后台清除缓存功能示例

    TP5(thinkPHP框架)实现后台清除缓存功能示例

    这篇文章主要介绍了TP5(thinkPHP框架)实现后台清除缓存功能,结合实例形式分析了thinkPHP5结合layui插件实现后台缓存清除相关的文件遍历、删除等操作技巧,需要的朋友可以参考下
    2019-05-05
  • php设计模式之模板模式实例分析【星际争霸游戏案例】

    php设计模式之模板模式实例分析【星际争霸游戏案例】

    这篇文章主要介绍了php设计模式之模板模式,基于星际争霸游戏案例形式分析了php模板模式相关原理与使用技巧,需要的朋友可以参考下
    2020-03-03

最新评论