这个递归函数究竟是哪里写错了?

发布于 2022-09-01 17:03:32 字数 1190 浏览 15 评论 0

$user_list为0时,竟然会再次重新调用,$user_list再次为0时,才会返回$result

function count_user_order($user_list_str, $limit = 4, $times = 1)
{
  static $result = array('users_count'=>array(), 'order_number'=>array(), 'order_amount'=>array());
  $sql = 'SELECT user_id FROM '.$GLOBALS['ecs']->table('users')." WHERE parent_id IN (%s)"; // 统计顾客
  $user_list = $GLOBALS['db']->getCol(sprintf($sql, $user_list_str));

  $sql_order = 'SELECT SUM(order_amount) order_amount,COUNT(*) order_number FROM '
  .$GLOBALS['ecs']->table('order_info')." WHERE pay_status=2 AND user_id IN (%s)"; // 统计订单数量及金额
  list($result['order_amount'][], $result['order_number'][]) = $GLOBALS['db']->getRow(sprintf($sql_order, $user_list_str));

  $result['users_count'][] = count($user_list);
  if ((!$limit || $times < $limit) && count($user_list)) {
    $user_list_str = implode(',', $user_list);
    count_user_order($user_list_str, $limit, ++$times);
  }

  return $result;
}

或许图片更容易看些:

clipboard.png

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

百善笑为先 2022-09-08 17:03:32

随便扫了下,应该是没有出口,就是没有停止递归的条件
还有你应该把统计顾客和统计订单数量及金额也写成一个函数

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文