refactor: count on the query, not collection

This commit introduces a short performance boost by counting the records in the query itself, instead of doing that in the collection Laravel returns.

Signed-off-by: miguel456 <me@nogueira.codes>
This commit is contained in:
Miguel Nogueira 2022-11-08 00:32:48 +00:00
parent 839219ae4b
commit f43ff4e9a0
No known key found for this signature in database
GPG Key ID: 3C6A7E29AF26D370
2 changed files with 6 additions and 6 deletions

View File

@ -32,9 +32,9 @@ class DashboardController extends Controller
public function index()
{
$totalPeerReview = Application::where('applicationStatus', 'STAGE_PEERAPPROVAL')->get()->count();
$totalNewApplications = Application::where('applicationStatus', 'STAGE_SUBMITTED')->get()->count();
$totalDenied = Application::where('applicationStatus', 'DENIED')->get()->count();
$totalPeerReview = Application::where('applicationStatus', 'STAGE_PEERAPPROVAL')->count();
$totalNewApplications = Application::where('applicationStatus', 'STAGE_SUBMITTED')->count();
$totalDenied = Application::where('applicationStatus', 'DENIED')->count();
$vacancies = Vacancy::where('vacancyStatus', '<>', 'CLOSED')->get();
$totalDeniedSingle = Application::where([
@ -50,7 +50,7 @@ class DashboardController extends Controller
return view('dashboard.dashboard')
->with([
'vacancies' => $vacancies,
'totalUserCount' => User::all()->count(),
'totalUserCount' => User::count(),
'totalDenied' => $totalDenied,
'totalPeerReview' => $totalPeerReview,
'totalNewApplications' => $totalNewApplications,

View File

@ -76,7 +76,7 @@ class UserController extends Controller
->with([
'users' => User::with('roles')->paginate('6'),
'numUsers' => count(User::all()),
'bannedUserCount' => Ban::all()->count(),
'bannedUserCount' => Ban::count(),
]);
}
@ -106,7 +106,7 @@ class UserController extends Controller
->with([
'users' => $matchingUsers,
'numUsers' => count(User::all()),
'bannedUserCount' => Ban::all()->count(),
'bannedUserCount' => Ban::count(),
]);
} else {
$request->session()->flash('error', __('Your search term did not return any results.'));