当前位置:首页 > PHP教程 > php应用 > 列表

PHP优化教程之解决嵌套问题

发布:smiling 来源: PHP粉丝网  添加日期:2022-04-11 16:05:38 浏览: 评论:0 

在开发过程中,我们经常遇到一对多的场景,

例如:查询订单列表,并且展示订单详情商品、数量数据

思路0:传统做法

a. 查询订单列表

b. 遍历订单详情

  1. $orderList = select * from order where xx; 
  2. foreach($orderList as $orderItem) { 
  3.     $orderItem->detailList = select * from order_detail where order_id = $orderItem->id; 

分析:查询SQL次数为:N+1(N为订单个数),这样频繁请求数据库,影响效率

优化:减少频繁请求数据库

思路1:

a. 查询订单列表后,利用in查出所有订单详情

b. 通过(订单表id => 订单详情表order_id)遍历匹配数据

  1. $orderList = select * from order where xx; 
  2. $orderId = array_pluck($orderList'id'); // Laravel内置数组辅助函数 
  3. $orderDetailList = select * from order_detail where order_id IN $orderId
  4. foreach($orderList as $orderItem) { 
  5.     $detailListTemp = []; 
  6.     foreach($orderDetailList as $orderDetailItem) { 
  7.         if ($orderItem->id == $orderDetailItem->order_id) { 
  8.             $detailListTemp[] = $orderDetailItem;        
  9.         } 
  10.     } 
  11.     $orderItem->detailList = $detailListTemp

分析:降低查询后,但2层遍历,复杂度较高,数量过大容易内存溢出

优化:降低复杂度

思路2:

a. 查询订单列表后,利用in查出所有订单详情

b. 订单详情列表转换成以订单ID为索引,用isset来匹配订单的详情

  1. $orderList = select * from order where xx; 
  2. $orderId = array_pluck($orderList'id'); // Laravel内置数组辅助函数 
  3. $orderDetailList = select * from order_detail where order_id IN $orderId
  4.  
  5. // 将订单详情转换成以订单ID为索引【方式1】 
  6. $orderDetailList = arrayGroup($orderDetailList'order_id'); 
  7. // 或:将订单详情转换成以订单ID为索引【方式2:如果为一对一,可以用array_column】 
  8. // $orderList = array_column($orderDetailList, null, 'order_id');  
  9.  
  10. foreach($orderList as $orderItem) { 
  11.     $orderItem->detailList = $orderDetailList[$orderItem->id] ?? []; 
  12.  
  13. // 根据KEY数组分组 
  14. function arrayGroup($list$key) { 
  15.  $newList = []; 
  16.  foreach ($list as $item) { 
  17.   $newList[$item[$key]][] = $item
  18.  } 
  19.  return $newList
  20. }

Tags: PHP优化教程 PHP嵌套

分享到: