การเรียงลำดับเริ่มต้นของผู้ให้บริการข้อมูล 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

42

หรือ

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

1
เข้ากันได้กับเอาต์พุต GII เริ่มต้นมากขึ้น
userlond

15

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 Guide of Data Provider

การเรียงลำดับโดยส่งเรียงลำดับวัตถุในแบบสอบถาม

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

7

หากคุณมี 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];

หากคุณต้องการทำในคอนโทรลเลอร์โดยไม่ต้องเปลี่ยน SearchModel นี่คือวิธีที่จะไป ขอบคุณ!
nunorbatista



-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.