Как бы я совместил две функции отклонения с PHP/ Laravel?
Как бы я провел рефакторинг кода ниже так, чтобы была только одна функция отклонения, а не две, и чтобы был только один вызов в БД вместо трех. Я также пытаюсь не иметь дубликатов.
$latestListings = $repo->whereExclusive(['property_status' => 'Active'],['created_at' => 'desc'],[],0, 4);
$latestListingsIds = $latestListings->map(function (Listing $listing) {
return $listing->id;
})->toArray();
$highCflListings = $repo->whereExclusive(['property_status' => 'Active'],['cfl' => 'desc'],[],0, 4);
$highCflListingIds = $highCflListings->map(function (Listing $listing) {
return $listing->id;
})->toArray();
$highCflListingsOccupied = $repo->whereExclusive(
['property_status' => 'Active', 'occupied_percentage' => 100],
['cfl' => 'desc'],
[],
0,
12
)->reject(function (Listing $listing) use ($latestListingsIds) {
return in_array($listing->id, $latestListingsIds);
})->reject(function (Listing $listing) use ($highCflListingIds) {
return in_array($listing->id, $highCflListingIds);
})->take(4);
1 ответ
Я не знаю как ты сидишь $latestListingsIds
а также $highCflListingIds
но если это просто массивы идентификаторов, объедините их и отклоните:
$exclude = $latestListingsIds + $highCflListingIds;
$highCflListingsOccupied = $repo->whereExclusive(['property_status' => 'Active', 'occupied_percentage' => 100], ['cfl' => 'desc'], [], 0, 12)
->reject(function (Listing $listing) use ($exclude) {
return in_array($listing->id, $exclude);
})
->take(4);