Laravel 框架让某个状态的数据固定在列表顶部(自定义排序)
Laravel 框架让某个状态的数据固定在列表顶部(自定义排序)
1.缘由
业务需要列表中某个状态处于列表顶部,该状态有多个值(例如:1-5),需要置于顶部的为中间的某个值(例如:2)
- status 为示例字段
2.实现
- 第一种实现方式
判断 status 的值是不是等于要置顶的值,起别名,然后再排序。
成功demo1:
$list->selectRaw("if(status=2,1,0) as need_order")
->orderBy('need_order','desc')
->orderBy('id','desc')
->get();
- 第二张实现方式
在 orderBy 时判断状态值,然后排序
成功demo2:
$list->orderByRaw(DB::raw("CASE WHEN status = 2 then 1 else 2 end"))
->orderBy('id','desc')
->get();
- 第三种方式
自定义排列顺序(2,1,3,4,5为示例,具体可按自己需求)
成功demo3:
$list->orderByRaw(DB::raw("FIELD(status, 2, 1,3,4,5)"))
->orderBy('id','desc')
->get();
本作品采用《CC 协议》,转载必须注明作者和本文链接