defaultOrder包含一个数组,其中键是列名,值是 a ,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();