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 协议》,转载必须注明作者和本文链接
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!