Domyślne sortowanie dostawcy danych Yii2

99

W Yii 1.1 ten kod działa dla domyślnego sortowania:

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

Jak można ustawić domyślne sortowanie w Yii2?

Wypróbowałem poniższy kod, ale bez wyniku:

$dataProvider = new ActiveDataProvider([
    'query' => $query,
    'sort' => ['defaultOrder'=>'topic_order asc']
]);
Sarvar Nishonboev
źródło

Odpowiedzi:

175

Myślę, że jest właściwe rozwiązanie. Skonfiguruj yii\data\Sortobiekt:

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

Oficjalny link do dokumentu

Alex
źródło
To rozwiązanie działa, ale wyszukiwanie w indeksie nie działa teraz.
Roby Sottini
42

Lub

       $dataProvider->setSort([
        'defaultOrder' => ['topic_order'=>SORT_DESC],
        'attributes' => [...
Kristīne Glode
źródło
1
Jest bardziej kompatybilny z domyślnym wyjściem GII
userlond
15

defaultOrder zawiera tablicę, w której klucz to nazwa kolumny, a wartość to a SORT_DESClub SORT_ASCdlatego poniższy kod nie działa.

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

Właściwa droga

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

Uwaga: Jeśli zapytanie zawiera już klauzulę orderBy, nowe instrukcje porządkowania podane przez użytkowników końcowych (poprzez konfigurację sortowania) zostaną dołączone do istniejącej klauzuli orderBy. Wszelkie istniejące klauzule limitu i offsetu zostaną nadpisane przez żądanie paginacji od użytkowników końcowych (poprzez konfigurację paginacji).

Możesz dowiedzieć się więcej z Yii2 Guide of Data Provider

Sortowanie Przez przekazanie obiektu Sort w zapytaniu

 $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();
Parth Chavda
źródło
6

jeśli masz CRUD (indeks) i potrzebujesz ustawić domyślne sortowanie kontrolera dla GridView, ListView lub więcej ... Przykład

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,
    ]);
}

musisz dodać

$dataProvider->sort->defaultOrder = ['id' => SORT_DESC];
Andrey Matveev
źródło
2

Spróbuj tego

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

$sort = $dataProvider->getSort();

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

$dataProvider->setSort($sort);
user210195
źródło
1
$dataProvider = new ActiveDataProvider([ 
    'query' => $query, 
    'sort'=> ['defaultOrder' => ['iUserId'=>SORT_ASC]] 
]);
Suraj Vaghela
źródło
-1

możesz zmodyfikować model wyszukiwania w ten sposób

$dataProvider = new ActiveDataProvider([
        'query' => $query,
        'sort' => [
            'defaultOrder' => ['user_id ASC, document_id ASC']
        ]
    ]);
brahmeswara rao Kamineni
źródło
-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]]
                                ]); 
jagjit singh
źródło