Laravel 5 Eloquent, где с несколькими или в пунктах

Я новичок в Laravel и пытаюсь получить результаты из таблицы с несколькими предложениями where и or.

Cases::select()
  ->where('accepting_id', '=', '1')
  ->where('status', '=', 'active')
  ->orWhere("status", '=', 'closed')
  ->orWhere("status", '=', 'canceled')
  ->orderBy('id', 'DESC')
  ->get();

Я получаю неверные данные, используя несколько orWhere

Стоит ли изучать 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
0
85
3
Перейти к ответу Данный вопрос помечен как решенный

Ответы 3

Вместо использования мульти orWhere() используйте whereIn()

Cases::select(`cols`)
    ->where('accepting_id', '=', '1')
    ->whereIn('status',  ['active', 'closed', 'canceled'])
    ->orderBy('id', 'DESC')
    ->get();

Также, если вы хотите сгруппировать некоторые запросы

Cases::select(`cols`)
    ->where('accepting_id', '=', '1')
    ->where(function ($q) {
        $q->where(`condition1`)
            ->orWhere(`condition1`);
    })
    ->orderBy('id', 'DESC')
    ->get();

Удалил мой ответ, так как твой лучше

thisiskelvin 07.06.2019 13:40

@thisiskelvin ваш ответ также полезен.

Davit Zeynalyan 07.06.2019 13:41

Это может помочь в другой ситуации

Davit Zeynalyan 07.06.2019 13:41

Вам нужно будет добавить предложения status where к закрытию where:

Cases::select()
    ->where('accepting_id', '=', '1')
    ->where(function($query) {
        $query->where('status', '=', 'active')
            ->orWhere("status", '=', 'closed')
            ->orWhere("status", '=', 'canceled');
    })
    ->orderBy('id', 'DESC')
    ->get();
return заявление не нужно
Davit Zeynalyan 07.06.2019 13:48
Ответ принят как подходящий
$user = Cases::select(`cols`)
              ->where('accepting_id', '=', '1')
              ->whereIn('status',  ['active', 'closed', 'canceled'])
              ->orderBy('id', 'DESC')
              ->get();

dd($user);

Попробуй это

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