Yii2 데이터 공급자 기본 정렬


99

Yii 1.1에서이 코드는 기본 정렬을 위해 작동합니다.

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

Yii2에서 기본 정렬을 어떻게 설정할 수 있습니까?

아래 코드를 시도했지만 결과가 없습니다.

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

답변:


175

적절한 해결책이 있다고 생각합니다. yii\data\Sort개체 구성 :

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

공식 문서 링크


이 솔루션은 작동하지만 인덱스 검색은 지금 작동하지 않습니다.
Roby Sottini 2011

42

또는

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

1
기본 GII 출력과 더 호환됩니다
userlond

15

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();

6

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];

2

이것을 시도하십시오

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

$sort = $dataProvider->getSort();

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

$dataProvider->setSort($sort);

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

-1

다음과 같이 검색 모델을 수정할 수 있습니다.

$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]]
                                ]); 
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.