Yii2: How to put null values to the end of an object list when sorting is ascending?

有些话、适合烂在心里 提交于 2019-12-10 11:07:55

问题


Here is my DataProvider:

$dataProvider = new ActiveDataProvider([
    'query'      => $query,
    'pagination' => ['pageSize' => 50],
    'sort'       => [
        'defaultOrder' => [
            'priority'      => SORT_DESC,
            'date_targeted' => SORT_ASC
        ]
     ]
]);

What I want is to move ("not set") to the end of the results.

How can I do this?


回答1:


You may add new field in select. And set in IF case like that:

$query->select([
    '*', 
    new \yii\db\Expression('IF(date_targeted IS NULL, 1, 0) AS date_targeted_flag')
]);

And in sort add date_targeted_flag:

'sort' => [
    'defaultOrder' => [
        'date_targeted_flag' => SORT_ASC,
        'priority'           => SORT_DESC,
        'date_targeted'      => SORT_ASC
    ],
    'attributes' => [
        'date_targeted_flag',
        'priority',
        'date_targeted'
    ]
]

This works fine - here and here.



来源:https://stackoverflow.com/questions/29071610/yii2-how-to-put-null-values-to-the-end-of-an-object-list-when-sorting-is-ascend

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!