Хобрук: Ваш путь к мастерству в программировании

Куда не имеет отношения в Laravel

У меня проблема с выполнением запроса с использованием Eloquent/Laravel.

Это моя модель: запрос содержит НОЛЬ или несколько предложений. Предложение можно скрыть (это атрибут, установленный в предложении).

Что мне нужно сделать, так это получить все запросы, которые либо имеют, либо не имеют предложений. НО, если есть связанное предложение, предложение должно иметь атрибут hide=false.

Я пробовал следующее, но, похоже, не работает.

$requests = Request::whereDoesntHave('offers', function ($query) use ($hideStatus) {
   $query->where('hide', true);
})->get();

Я думаю, что он возвращает мне только запросы, в которых вообще нет предложений.

Есть идеи?

К вашему сведению, у меня Laravel 5.4

Любая помощь будет принята с благодарностью!

Спасибо

13.11.2017

  • Я думаю, вы должны написать 2 отдельных запроса, где 1 будет фильтровать данные предложения с помощью hide=false, а другой запрос, где предложение не существует. 13.11.2017
  • Да.... Я думаю, что с ответом @Saumini ниже мы на правильном пути, но все еще не на 100%... возможно, некоторые синтаксические ошибки.. 13.11.2017

Ответы:


1

Проверьте ниже запрос. Я не тестировал запрос, написал его со своими знаниями.

$requests = Request::whereHas('offers', function ($query) {
                    $query->where('hide', false);
                })
                ->orDoesntHave('offers')
                ->get();
13.11.2017
  • Спасибо за ваш ответ. К сожалению, это не работает. Я получаю сообщение об ошибке Вызов неопределенного метода Illuminate\Database\Query\Builder::orDoesntHave(). 13.11.2017

  • 2

    Спасибо всем за ваши ответы. "или не имеет" не работает. Вместо этого кажется, что работает следующее:

    $requests = Request::whereHas('offers', function ($query) {
                    $query->where('hide', false);
                })
                ->doesntHave('offers', 'or')
                ->get();
    
    14.11.2017
    Новые материалы

    Не зря же это называют интеллектом
    Стек — C#, Oracle Опыт — 4 года Работа — Разведывательный корпус Мне пора служить Может быть, я немного приукрашиваю себя, но там, где я живу, есть обязательная военная служба на 3..

    LeetCode Проблема 41. Первый пропущенный положительный результат
    LeetCode Проблема 41. Первый пропущенный положительный результат Учитывая несортированный массив целых чисел, найдите наименьшее пропущенное положительное целое число. Пример 1: Input:..

    Расистский и сексистский робот, обученный в Интернете
    Его ИИ основан на предвзятых данных, которые создают предрассудки. Он словно переходит из одного эпизода в другой из серии Черное зеркало , а вместо этого представляет собой хронику..

    Управление состоянием в микрофронтендах
    Стратегии бесперебойного сотрудничества Микро-фронтенды — это быстро растущая тенденция в сфере фронтенда, гарантирующая, что удовольствие не ограничивается исключительно бэкэнд-системами..

    Декларативное и функциональное программирование в стиле LINQ с использованием JavaScript с использованием каррирования и генератора ...
    LINQ - одна из лучших функций C #, которая обеспечивает элегантный способ написания кода декларативного и функционального стиля, который легко читать и понимать. Благодаря таким функциям ES6,..

    Структуры данных в C ++ - Часть 1
    Реализация общих структур данных в C ++ C ++ - это расширение языка программирования C, которое поддерживает создание классов, поэтому оно известно как C с классами . Он используется для..

    Как я опубликовал свое первое приложение в App Store в 13 лет
    Как все началось Все началось три года назад летом после моего четвертого класса в начальной школе. Для меня, четвертого класса, лето кажется бесконечным, пока оно не закончится, и мой отец..