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 协议》,转载必须注明作者和本文链接
          
                    
                    
          
          
                关于 LearnKu
              
                    
                    
                    
 
推荐文章: