where('plan_id', '!=', NULL) ->where(function ($query) { $query->where('expired_at', '>=', time()) ->orWhere('expired_at', NULL); }) ->groupBy("plan_id") ->get(); $plans = Plan::orderBy('sort', 'ASC')->get(); foreach ($plans as $k => $v) { $plans[$k]->count = 0; foreach ($counts as $kk => $vv) { if ($plans[$k]->id === $counts[$kk]->plan_id) $plans[$k]->count = $counts[$kk]->count; } } return response([ 'data' => $plans ]); } }