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

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

SELECT *
FROM mytable
ORDER BY
  coloumn1 DESC, coloumn2 ASC

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

Ответ 1

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

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

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

SELECT * FROM `users` ORDER BY `name` DESC, `email` ASC

Ответ 2

Вы можете сделать, как указал @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();

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