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