Сортировка по умолчанию поставщика данных Yii2

В Yii 1.1 этот код работает для сортировки по умолчанию:

$dataProvider = new CActiveDataProvider('article',array(
    'sort'=>array(
        'defaultOrder'=>'id DESC',
    ),
));

Как можно настроить сортировку по умолчанию в Yii2?

Пробовал код ниже, но безрезультатно:

$dataProvider = new ActiveDataProvider([
    'query' => $query,
    'sort' => ['defaultOrder'=>'topic_order asc']
]);

person Sarvar Nishonboyev    schedule 10.04.2014    source источник


Ответы (6)


Думаю, есть правильное решение. Настройте объект yii\data\Sort:

 $dataProvider = new ActiveDataProvider([
     'query' => $query,
     'sort'=> ['defaultOrder' => ['topic_order' => SORT_ASC]],
 ]);

Официальная ссылка на документ

person Alex    schedule 10.04.2014
comment
Это решение работает, но поиск по индексу сейчас не работает. - person Roby Sottini; 16.11.2017

defaultOrder содержат массив, где ключ - это имя столбца, а значение - SORT_DESC или SORT_ASC, поэтому приведенный ниже код не работает.

$dataProvider = new ActiveDataProvider([
        'query' => $query,
        'sort' => ['defaultOrder'=>'topic_order asc']
    ]);

Правильный путь

$dataProvider = new ActiveDataProvider([
    'query' => $query,
    'sort' => [
        'defaultOrder' => [
            'topic_order' => SORT_ASC,
        ]
    ],
]);

Примечание. Если в запросе уже указано предложение orderBy, новые инструкции по упорядочиванию, предоставленные конечными пользователями (через конфигурацию сортировки), будут добавлены к существующему предложению orderBy. Любые существующие пункты ограничения и смещения будут перезаписаны запросом пагинации от конечных пользователей (через конфигурацию пагинации).

Подробные сведения можно найти в Руководстве поставщика данных по Yii2.

Сортировка путем передачи объекта Sort в запросе

 $sort = new Sort([
        'attributes' => [
            'age',
            'name' => [
                'asc' => ['first_name' => SORT_ASC, 'last_name' => SORT_ASC],
                'desc' => ['first_name' => SORT_DESC, 'last_name' => SORT_DESC],
                'default' => SORT_DESC,
                'label' => 'Name',
            ],
        ],
    ]);

    $models = Article::find()
        ->where(['status' => 1])
        ->orderBy($sort->orders)
        ->all();
person Parth Chavda    schedule 10.05.2016

если у вас есть CRUD (индекс) и вам нужно установить сортировку вашего контроллера по умолчанию для GridView, или ListView, или более ... Пример

public function actionIndex()
{
    $searchModel = new NewsSearch();
    $dataProvider = $searchModel->search(Yii::$app->request->queryParams);
    // set default sorting
    $dataProvider->sort->defaultOrder = ['id' => SORT_DESC];

    return $this->render('index', [
        'searchModel' => $searchModel,
        'dataProvider' => $dataProvider,
    ]);
}

вам нужно добавить

$dataProvider->sort->defaultOrder = ['id' => SORT_DESC];
person Andrey Matveev    schedule 08.11.2018
comment
если вы хотите сделать это в контроллере, не меняя SearchModel, это правильный вариант. Спасибо! - person nunorbatista; 31.08.2020

Попробуй это

$dataProvider = new ActiveDataProvider([
    'query' => $query,
]);

$sort = $dataProvider->getSort();

$sort->defaultOrder = ['id' => SORT_ASC];

$dataProvider->setSort($sort);
person user210195    schedule 07.06.2018

вы можете изменить модель поиска следующим образом

$dataProvider = new ActiveDataProvider([
        'query' => $query,
        'sort' => [
            'defaultOrder' => ['user_id ASC, document_id ASC']
        ]
    ]);
person brahmeswara rao Kamineni    schedule 25.11.2017

person    schedule
comment
Он более совместим с выходом GII по умолчанию - person userlond; 11.05.2015