У меня есть две таблицы, типичная мастер-деталь, и я собираюсь получить основные записи, в то время как регистрационный номер, полученный с помощью отношения, где, больше, чем n
Я делал это до сих пор
Master::withTrashed()
->with('details')
->withCount(['details' => function ($query) {
$query->whereDate('date_init', '<', Carbon::now()->toDateString());
}]);
с этим я получаю мастер и его детали с заданными условиями, но есть учителя, у которых счетчик отношения равен 0, и я хочу игнорировать их. Как я могу это сделать?
@aynber Да, но я понимаю, что это необходимо для добавления ограничений в отношения, но если условие ложно, оно не перестает показывать, что мастер показывает только пустую деталь.






Master::withTrashed()
->has('details')
->with('details')
->withCount(['details' => function ($query) {
$query->whereDate('date_init', '<', Carbon::now()->toDateString());
}]);
Исправлено whereHas to has, как указал Намошек.
Спасибо за ответ, но это не то, что я объясняю в своем вопросе, ваш ответ никоим образом не устраняет мастер с счетом, равным 0;
Фактически, это должен быть has('details'), и тогда он действительно устраняет мастер. Вам понадобится whereHas('details', function ($query) { $query->whereDate('date_init', '<', now()->toDateString()); }), если вы хотите выполнить запрос о существовании с прикрепленным условием.
Вы ищете следующий запрос:
Master::withTrashed()
->with(['details' => function ($query) {
$query->whereDate('date_init', '<', now());
}])
->whereHas('details', function ($query) {
$query->whereDate('date_init', '<', now());
})
->get();
Запрос буквально означает:
Give me all
Masters, also the deleted ones, which have at least one attachedDetailwith an initialization date in the past. Also eager load all attachedDetailswhich have been initialized in the past.
Вы смотрели
whereHas? laravel.com/docs/master/…