Как использовать порядок для нескольких столбцов в 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(); Надеюсь, это поможет:)
Ответ 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(); Надеюсь, это поможет:)