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