Заказ по запросу с использованием 2 столбцов с использованием laravel

Вот образец моей структуры базы данных:

id |    name    |   role   |   login_status   |
-----------------------------------------------
 1      mark        user           1
 2      john       lawyer          0
 3      david       user           0
 4      erik       lawyer          0

Я хочу упорядочить их таким образом, чтобы пользователи с ролью lawyer были в верхней части списка, за которыми следовали пользователи со значением 1 в столбце login_status.

Я использовал orderBy('login_status','desc') для столбца login_status, но у меня проблемы с состоянием столбца role.

ожидаемый результат:

- john
- erik
- mark
- david

Любая помощь будет оценена по достоинству. Спасибо.

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

Ответы 2

Вы можете использовать UNION

select * from table where role='lawyer' order by login_status desc
UNION
select * from table where role!='lawyer' order by login_status desc
Ответ принят как подходящий

Вы можете использовать выражение case для своих критериев

->orderByRaw("CASE WHEN role ='lawyer' THEN 1 ELSE 0 END DESC")
->orderBy( 'login_status', 'DESC' );

Обычный sql будет похож

select *
from demo
order by CASE WHEN role ='lawyer' THEN 1 ELSE 0 END DESC, login_status DESC

Демо

Или вы можете сделать свой заказ еще короче, например

order by role ='lawyer' DESC, login_status DESC

Демо

Разве у вас не может быть просто два заказа: один для роли, другой для login_status? Или это не сработает?

hungrykoala 22.05.2018 08:02

Спасибо брат. Я использовал первое решение, которое вы дали, и оно сработало. :)

Ronald Torres 22.05.2018 08:13

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