Yii2数据提供程序默认排序

108

在Yii 1.1中,以下代码可用于默认排序:

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

Yii2中如何设置默认排序方式?

尝试了以下代码,但没有结果:

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

198

我认为有一个合适的解决方案。配置yii\data\Sort对象:

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

官方文档链接


这个解决方案可行,但是索引中的搜索现在不起作用。 - Roby Sottini

42
       $dataProvider->setSort([
        'defaultOrder' => ['topic_order'=>SORT_DESC],
        'attributes' => [...

1
它与默认的GII输出更兼容。 - userlond

18

defaultOrder 包含一个数组,其中键是列名,值为 SORT_DESCSORT_ASC,这就是下面的代码无法正常工作的原因。

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

正确的方式

$dataProvider = new ActiveDataProvider([
    'query' => $query,
    'sort' => [
        'defaultOrder' => [
            'topic_order' => SORT_ASC,
        ]
    ],
]);
注意:如果查询已经指定了orderBy子句,那么最终用户通过排序配置所给出的新排序指令将附加到现有的orderBy子句中。任何现有的limit和offset子句都将被最终用户通过分页配置的分页请求所覆盖。
你可以从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();

13

如果您有 CRUD(索引)并且需要为 GridView、ListView 等设置默认排序,请在控制器中进行操作... 例如:

若您需要为 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];

如果你想在不改变SearchModel的情况下在控制器中完成它,这是可行的方法。谢谢! - nunorbatista

4
尝试这个:

尝试这一个

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

$sort = $dataProvider->getSort();

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

$dataProvider->setSort($sort);

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

0

你可以像这样使用排序属性

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

如果你想按照两个字段进行排序,例如 topic_order1 和 topic_order2,你可以这样做

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

1
你好,你的回答并没有提供任何新的内容;请不要抄袭他人的作品而不注明来源。阅读帮助文档:如何回答问题 - pierpy

-1

指南所述,您必须通过配置数据提供程序的排序属性来指定其排序行为,这些属性对应于yii\data\Sort的配置。

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

重复的回答。来自 2014 年的 https://dev59.com/y2Ag5IYBdhLWcg3w7uyk#22994046 答案已经有相同的代码,并被标记为正确答案。 - Néstor

-2

你可以像这样修改搜索模型

$dataProvider = new ActiveDataProvider([
        'query' => $query,
        'sort' => [
            'defaultOrder' => ['user_id ASC, document_id ASC']
        ]
    ]);

-2
    $modelProduct       =   new Product();
    $shop_id            =   (int)Yii::$app->user->identity->shop_id;

    $queryProduct       =   $modelProduct->find()
                            ->where(['product.shop_id'  => $shop_id]);


    $dataProviderProduct    =   new ActiveDataProvider([
                                    'query'         =>  $queryProduct,
                                     'pagination' => [ 'pageSize' => 10 ],
                                    'sort'=> ['defaultOrder' => ['id'=>SORT_DESC]]
                                ]); 

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接