Упорядочить по запросу, используя 2 столбца, используя laravel - PullRequest
0 голосов
/ 22 мая 2018

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

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

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

Ответы [ 2 ]

0 голосов
/ 22 мая 2018

Вы можете использовать выражение 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

Демо

0 голосов
/ 22 мая 2018

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

select * from table where role='lawyer' order by login_status desc
UNION
select * from table where role!='lawyer' order by login_status desc
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...