Фильтруйте элементы, подсчитывая их взаимосвязь Laravel5

У меня есть две таблицы, типичная мастер-деталь, и я собираюсь получить основные записи, в то время как регистрационный номер, полученный с помощью отношения, где, больше, чем n

Я делал это до сих пор

Master::withTrashed()
->with('details')
->withCount(['details' => function ($query) {

    $query->whereDate('date_init', '<', Carbon::now()->toDateString()); 
}]);

с этим я получаю мастер и его детали с заданными условиями, но есть учителя, у которых счетчик отношения равен 0, и я хочу игнорировать их. Как я могу это сделать?

Вы смотрели whereHas? laravel.com/docs/master/…

aynber 07.12.2018 17:28

@aynber Да, но я понимаю, что это необходимо для добавления ограничений в отношения, но если условие ложно, оно не перестает показывать, что мастер показывает только пустую деталь.

DarkFenix 07.12.2018 17:31
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
2
27
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Master::withTrashed()
->has('details')
->with('details')
->withCount(['details' => function ($query) {

    $query->whereDate('date_init', '<', Carbon::now()->toDateString()); 
}]);

Исправлено whereHas to has, как указал Намошек.

Спасибо за ответ, но это не то, что я объясняю в своем вопросе, ваш ответ никоим образом не устраняет мастер с счетом, равным 0;

DarkFenix 07.12.2018 17:35

Фактически, это должен быть has('details'), и тогда он действительно устраняет мастер. Вам понадобится whereHas('details', function ($query) { $query->whereDate('date_init', '<', now()->toDateString()); }), если вы хотите выполнить запрос о существовании с прикрепленным условием.

Namoshek 07.12.2018 17:41
Ответ принят как подходящий

Вы ищете следующий запрос:

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 attached Detail with an initialization date in the past. Also eager load all attached Details which have been initialized in the past.

Другие вопросы по теме