业务需要列表中某个固定用户数据处于列表顶部,该用户author状态有多个值(例如:1-999),需要置于顶部的为中间的某个值(例如:author=68)
实现方式:
1、判断 author的值是不是等于要置顶的值,起别名,然后再排序。
$list->selectRaw("if(author=68,1,0) as need_order")
->orderBy('need_order','desc')
->orderBy('id','desc')
->get();
2、在 orderBy 时判断状态值,然后排序
$list->orderByRaw(DB::raw("CASE WHEN status = 2 then 1 else 2 end"))
->orderBy('id','desc')
->get();
3、自定义排列顺序(2,1,3,4,5 为示例,具体可按自己需求)
$list->orderByRaw(DB::raw("FIELD(status, 2, 1,3,4,5)"))
->orderBy('id','desc')
->get();