php优化foreach里循环查询,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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值