Как использовать Order By для нескольких столбцов в Laravel 4?

119

Я хочу сортировать несколько столбцов в Laravel 4 с помощью метода orderBy() от Eloquent. Запрос будет генерировать Eloquent следующим образом:

SELECT *
FROM mytable
ORDER BY
  coloumn1 DESC, coloumn2 ASC

Как я могу это сделать?

  • 0
    Очень просто. User::orderBy('name', 'DESC') ->orderBy('email', 'ASC') ->get();
Теги:

2 ответа

196
Лучший ответ

Просто запустите orderBy() столько раз, сколько вам нужно. Например:

User::orderBy('name', 'DESC')
    ->orderBy('email', 'ASC')
    ->get();

Выдает следующий запрос:

SELECT * FROM `users` ORDER BY `name` DESC, `email` ASC
  • 14
    Было бы хорошо, если бы мы могли передать массив, например: User::orderBy(array('name'=>'desc', 'email'=>'asc'))
  • 10
    @FireCoding, вы можете сделать $user->orders = array(array('column' => 'name', 'direction' => 'desc'), array('column' => 'email', 'direction' => 'asc'));
Показать ещё 3 комментария
6

Вы можете сделать, как указал @rmobis в своем ответе, [Добавление в него чего-то большего]

Использование order by дважды:

MyTable::orderBy('coloumn1', 'DESC')
    ->orderBy('coloumn2', 'ASC')
    ->get();

и второй способ сделать это,

Использование raw order by:

MyTable::orderByRaw("coloumn1 DESC, coloumn2 ASC");
    ->get();

Оба будут выдавать тот же запрос, что и ниже,

SELECT * FROM `my_tables` ORDER BY `coloumn1` DESC, `coloumn2` ASC

Как @rmobis, указанный в комментарии первого ответа, вы можете пройти как массив для упорядочения по столбцу, как это,

$myTable->orders = array(
    array('column' => 'coloumn1', 'direction' => 'desc'), 
    array('column' => 'coloumn2', 'direction' => 'asc')
);

еще один способ сделать это: iterate в цикле,

$query = DB::table('my_tables');

foreach ($request->get('order_by_columns') as $column => $direction) {
    $query->orderBy($column, $direction);
}

$results = $query->get();

Надеюсь, это поможет:)

  • 0
    Могу ли я использовать orderByRaw и orderBy вместе? кажется, не работает для меня, результирующий запрос, кажется, только уважать orderByRaw
  • 0
    попробуйте сначала выставить orderBy, а затем orderByRaw и увидеть результат @GeorgeAvgoustis
Показать ещё 2 комментария

Ещё вопросы

Сообщество Overcoder
Наверх
Меню