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

吾爱主题 阅读:162 2021-11-09 15:05:00 评论:0

php代码优化

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

foreach里面执行两次sql查询

?
1 2 3 4 5 6 7 // $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查询

?
1 2 3 4 5 6 7 8 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中的查询移到外面 ?
1 2 3 4 5 6 7 8 9 // $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' ];      }    } }

小结

?
1 2 // 返回数据 return $datas ;

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

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

原文链接:https://blog.csdn.net/sshfl_csdn/article/details/45742807

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容