Laravel - SQL-запрос с реляционными несколькими строками

У меня есть запрос, который получает учетные данные официальных лиц, хотя он может вернуть много строк, если они есть у пользователя.

Я пытаюсь получить запрос, где ЕСЛИ для одной из строк столбца renew установлено значение 1, игнорируйте его, иначе верните результаты, если он все еще 0

$officiants = Officiant::where('status', 1)
            ->whereHas('cred',function($q) {
                $q->where('renewal', 0);
            })
            ->get();

Можете ли вы показать свою модель Officiant и cred?

morgan9999 01.05.2018 16:49
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
В последние годы архитектура микросервисов приобрела популярность как способ построения масштабируемых и гибких приложений. Laravel , популярный PHP...
Как построить CRUD-приложение в Laravel
Как построить CRUD-приложение в Laravel
Laravel - это популярный PHP-фреймворк, который позволяет быстро и легко создавать веб-приложения. Одной из наиболее распространенных задач в...
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
В предыдущем посте мы создали функциональность вставки и чтения для нашей динамической СУБД. В этом посте мы собираемся реализовать функции обновления...
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
Роли и разрешения пользователей без пакета Laravel 9
Роли и разрешения пользователей без пакета Laravel 9
Этот пост изначально был опубликован на techsolutionstuff.com .
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
0
1
43
2

Ответы 2

$officiants = Officiant::where('status', 1)
        ->whereHas('cred',function($q) {
            $q->where('renewal', 0);
        })->with([‘cred’=> function($query) {
                $query->where('renewal', 0);
           })
        ->get();

Если вы хотите получить должное внимание, вам понадобится этот запрос.

Officiant Cred имеет строки, если какая-либо из строк возвращает обновление 1, игнорируйте, иначе верните результаты

Victor 01.05.2018 16:53

Да, вам нужны все кредиты со значением обновления 0, верно?

Muhammad Nauman 01.05.2018 16:54

Да, хотя, если в каких-либо строках стоит 1, НЕ возвращать

Victor 01.05.2018 16:57

Вы выполнили вышеуказанный запрос?

Muhammad Nauman 01.05.2018 16:58

очевидно у меня есть

Victor 01.05.2018 16:59

Вы должны использовать orWhere(), он также будет извлекать строки с обновлением = 1

$officiants = Officiant::where('status', 1)
            ->whereHas('cred',function($q) {
                $q->where('renewal', 0);
                 $q->orWhere('renewal',1);    
            })

            ->with(['cred' => function($q) {
                $q->where('renewal', 1);
                $q->where('renewal', 0); 
            }])
            ->get();

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