返回顶部
首页 > 资讯 > 后端开发 > PHP编程 >php优化查询foreach代码实例讲解
  • 483
分享到

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

2024-04-02 19:04:59 483人浏览 薄情痞子
摘要

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

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

--结束END--

本文标题: php优化查询foreach代码实例讲解

本文链接: https://lsjlt.com/news/122118.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • php优化查询foreach代码实例讲解
    php代码优化 应避免在php foreach里面进行sql查询 以下代码示例使用了laravel的操作数据库api,eloquent orm foreach里面执行两次sql查询 ...
    99+
    2024-04-02
  • 实例讲解MySQL数据库的查询优化技术(转)
    实例讲解MySQL数据库的查询优化技术(转)[@more@]  数据库系统是管理信息系统的核心,基于数据库的联机事务处理(OLTP)以及联机分析处理(OLAP)是银行、企业、政府等部门最为重要的计算机应用之...
    99+
    2024-04-02
  • 实例讲解MySQL 慢查询
    简介        开启慢查询日志,可以让MySQL记录下查询超过指定时间的语句,通过定位分析性能的瓶颈,才能更好的优化数据库系统的性能。 一、配...
    99+
    2022-05-25
    MySQL 慢查询 MySQL 查询
  • MySQL通过实例化对象参数查询实例讲解
    本篇文章给大家带来的内容是关于MySQL如何通过实例化对象参数查询数据 ?(源代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 public static string Query...
    99+
    2024-04-02
  • 示例讲解php查询时间戳
    在开发中,我们通常需要对时间进行查询和比较。而在 PHP 中,时间戳是处理时间问题的重要概念之一。本文将介绍 PHP 查询时间戳的方法和应用场景。时间戳是什么?时间戳是从 1970 年 1 月 1 日 00:00:00 UTC 到当前时间的...
    99+
    2023-05-14
    php
  • Oracle分页查询性能优化代码详解
    对于数据库中表的数据的 Web 显示,如果没有展示顺序的需要,而且因为满足条件的记录如此之多,就不得不对数据进行分页处理。常常用户并不是对所有数据都感兴趣的,或者大部分情况下,他们只看前几页。 通常有以...
    99+
    2024-04-02
  • laravel日志优化实例讲解
    日志浏览 扩展地址:arcanedev/log-viewer 安装扩展 composer require arcanedev/log-viewer 注册服务,在config/a...
    99+
    2024-04-02
  • 实例讲解php怎么查询图片是否转换
    随着互联网的发展,图片处理技术也在不断提高,图片格式也有了更多的选择。其中,常见的图片格式有JPEG、PNG、GIF等等。不同的格式对于不同的需求有着不同的优劣势。作为一名PHP开发者,在开发过程中,我们经常需要对图片进行处理,其中一个关键...
    99+
    2023-05-14
  • oracle精确查询和模糊查询实例代码
    本篇内容主要讲解“oracle精确查询和模糊查询实例代码”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“oracle精确查询和模糊查询实例代码”吧!精确查询:SE...
    99+
    2024-04-02
  • MySQL实例讲解子查询的使用
    目录子查询-嵌套查询原始查询方法自连接子查询子查询分类单行子查询子查询的编写思路HAVING中的子查询CASE中的子查询子查询中的空值问题多行子查询多行比较操作符相关子查询EXISTS与NOT EXISTS 关键...
    99+
    2023-03-02
    MySQL子查询语句 MySQL子查询写法
  • PHP代码优化的示例分析
    这篇文章主要介绍了PHP代码优化的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一小段“劣质”的PHP代码优化的过程,请仔细体会优化...
    99+
    2024-04-02
  • laravel join关联查询代码实例
    laravel join关联查询 1、两表关联 $fbaInventoryTb = (new \App\Model\Amz\Fba\InventoryReport)->...
    99+
    2024-04-02
  • MySQL范围查询优化的场景实例详解
    目录思考题范围查询-基础场景一: a = 1 and b = 2 and c = 3场景二: a > 1 and b = 2场景三:a > 1 and b = 2 and c > 3场景四: a >...
    99+
    2022-06-13
    mysql时间范围查询优化 mysql范围查询 mysql范围查询会使用索引吗
  • SQL查询优化原理实例分析
    今天小编给大家分享一下SQL查询优化原理实例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。有一张财务流水表,未分库分表,...
    99+
    2023-07-02
  • python 代码检查,实现行级代码优化
        有时候运行一个python程序,它需要运行很长时间。你或许想提升该程序的运行效率。那该怎么做那?     首先需要你要找到该程序瓶颈在哪里~   比如,哪个函数的运行花费时间比较长? 哪个函数占用内存比较多,是否需要优化对内存的使用...
    99+
    2023-01-31
    代码 python
  • PHP 性能优化:代码审查技巧
    php代码审查优化技巧:识别性能密集型功能。检查sql查询,使用索引和优化联接。利用缓存,避免重复查询或计算。审查内存使用,识别潜在的内存问题。实战案例:优化图像上传脚本,使用file_...
    99+
    2024-05-10
    性能优化 代码审查 redis
  • PostgreSQL 源码解读(37)- 查询语句#22(查询优化-grouping_plan...
    在主函数subquery_planner完成外连接消除后,接下来调用grouping_planner函数,本节简单介绍了此函数的主体逻辑。 一、源码解读 grouping_plan...
    99+
    2024-04-02
  • sqlserver多表联合查询和多表分页查询的代码讲解
    这篇文章主要为大家详细介绍了sqlserver多表联合查询和多表分页查询的方法,图文详解容易学习,配合代码阅读理解效果更佳,非常适合初学者入门,感兴趣的小伙伴们可以参考一下。多表联查:select...
    99+
    2024-04-02
  • oracle多表简单查询实例代码
    目录多表查询基本语法oracle多表查询总结多表查询基本语法 笛卡尔积在SQL中的实现方式既是交叉连接(Cross Join)。所有连接方式都会先生成临时笛卡尔积表,笛卡尔积是关系代...
    99+
    2024-04-02
  • MySQL中join查询实例代码分析
    这篇“MySQL中join查询实例代码分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“M...
    99+
    2022-11-30
    mysql join
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作