getCourses($reviews); foreach ($reviews as $key => $review) { $reviews[$key]['course'] = $courses[$review['course_id']]; } return $reviews; } public function handleUsers($reviews) { $users = $this->getUsers($reviews); foreach ($reviews as $key => $review) { $reviews[$key]['user'] = $users[$review['user_id']]; } return $reviews; } protected function getCourses($reviews) { $ids = kg_array_column($reviews, 'course_id'); $courseRepo = new CourseRepo(); $courses = $courseRepo->findByIds($ids, ['id', 'title'])->toArray(); $result = []; foreach ($courses as $course) { $result[$course['id']] = $course; } return $result; } protected function getUsers($reviews) { $ids = kg_array_column($reviews, 'user_id'); $userRepo = new UserRepo(); $users = $userRepo->findByIds($ids, ['id', 'name', 'avatar'])->toArray(); $result = []; foreach ($users as $user) { $result[$user['id']] = $user; } return $result; } }