PHP优化教程之解决嵌套问题
在开发过程中,我们经常遇到一对多的场景,
例如:查询订单列表,并且展示订单详情商品、数量数据
思路0:传统做法
a.查询订单列表
b.遍历订单详情
$orderList=select*fromorderwherexx; foreach($orderListas$orderItem){ $orderItem->detailList=select*fromorder_detailwhereorder_id=$orderItem->id; }
分析:查询SQL次数为:N+1(N为订单个数),这样频繁请求数据库,影响效率
优化:减少频繁请求数据库
思路1:
a.查询订单列表后,利用in查出所有订单详情
b.通过(订单表id=>订单详情表order_id)遍历匹配数据
$orderList=select*fromorderwherexx; $orderId=array_pluck($orderList,'id');//Laravel内置数组辅助函数 $orderDetailList=select*fromorder_detailwhereorder_idIN$orderId; foreach($orderListas$orderItem){ $detailListTemp=[]; foreach($orderDetailListas$orderDetailItem){ if($orderItem->id==$orderDetailItem->order_id){ $detailListTemp[]=$orderDetailItem; } } $orderItem->detailList=$detailListTemp; }
分析:降低查询后,但2层遍历,复杂度较高,数量过大容易内存溢出
优化:降低复杂度
思路2:
a.查询订单列表后,利用in查出所有订单详情
b.订单详情列表转换成以订单ID为索引,用isset来匹配订单的详情
$orderList=select*fromorderwherexx; $orderId=array_pluck($orderList,'id');//Laravel内置数组辅助函数 $orderDetailList=select*fromorder_detailwhereorder_idIN$orderId; //将订单详情转换成以订单ID为索引【方式1】 $orderDetailList=arrayGroup($orderDetailList,'order_id'); //或:将订单详情转换成以订单ID为索引【方式2:如果为一对一,可以用array_column】 //$orderList=array_column($orderDetailList,null,'order_id'); foreach($orderListas$orderItem){ $orderItem->detailList=$orderDetailList[$orderItem->id]??[]; } //根据KEY数组分组 functionarrayGroup($list,$key){ $newList=[]; foreach($listas$item){ $newList[$item[$key]][]=$item; } return$newList; }
总结
到此这篇关于PHP优化教程之解决嵌套问题的文章就介绍到这了,更多相关PHP解决嵌套问题内容请搜索毛票票以前的文章或继续浏览下面的相关文章希望大家以后多多支持毛票票!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。