Як користуватися замовленням для кількох стовпців у Laravel 4?


231

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

SELECT *
FROM mytable
ORDER BY
  coloumn1 DESC, coloumn2 ASC

Як я можу це зробити?


Дуже просто. User::orderBy('name', 'DESC') ->orderBy('email', 'ASC') ->get();
Я найдурніша людина

Відповіді:


373

Просто викликайте orderBy()стільки разів, скільки вам потрібно. Наприклад:

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

Створює такий запит:

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

16
Було б добре, якби ми могли пройти масив на кшталт: User::orderBy(array('name'=>'desc', 'email'=>'asc'))
JoshuaDavid

10
@FireCoding, можна зробити$user->orders = array(array('column' => 'name', 'direction' => 'desc'), array('column' => 'email', 'direction' => 'asc'));
rmobis

Чи є спосіб додати orderBy за встановленим запитом?
Рафаель

@ Rafael, якщо ви його ще не виконували (дзвонили getчи first), просто зателефонуйте orderBy. Ще, ні.
rmobis

В іншому випадку, якщо вам завжди потрібно замовити за desc, ви можете також використовувати найновіший ().
ssi-anik

30

Ви можете зробити так, як @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();

Сподіваюся, це допомагає :)


Чи можу я користуватися orderByRaw AND orderBy разом? здається, не працює для мене, одержуваний запит, здається, лише поважає orderByRaw
Return-1,

спробуйте спочатку замовити замовлення, а потім замовитиByRaw і побачити результат @GeorgeAvgoustis
Sagar Naliyapara

на жаль, цього неможливо зробити, оскільки спочатку потрібно рандомізувати, а потім замовити остаточний класифікатор.
Повернення-1,

1
Це може працювати разом, тому що, застосовуючи при сортуванні першого стовпця, ви не можете побачити сортування другого стовпця
Sagar Naliyapara

3

Ось ще один ухил, який я придумав для свого базового класу сховищ, де мені потрібно було замовити довільну кількість стовпців:

public function findAll(array $where = [], array $with = [], array $orderBy = [], int $limit = 10)
{
    $result = $this->model->with($with);
    $dataSet = $result->where($where)
        // Conditionally use $orderBy if not empty
        ->when(!empty($orderBy), function ($query) use ($orderBy) {
            // Break $orderBy into pairs
            $pairs = array_chunk($orderBy, 2);
            // Iterate over the pairs
            foreach ($pairs as $pair) {
                // Use the 'splat' to turn the pair into two arguments
                $query->orderBy(...$pair);
            }
        })
        ->paginate($limit)
        ->appends(Input::except('page'));

    return $dataSet;
}

Тепер ви можете телефонувати так:

$allUsers = $userRepository->findAll([], [], ['name', 'DESC', 'email', 'ASC'], 100);
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.