使用lumen框架,$model为当前的店铺表
1、店铺列表中按销量的排序
1、得到按销量排序的店铺id $ruidList=\App\Models\Goods::select('user_id')->groupBy('user_id')->orderByRaw(' sum(sales_volume)')->offset($current)->limit($size)->get()->toArray();2、整理店铺id排序为1,2,3的格式 $str=''; foreach ($ruidList as $item) { $str.=$item['user_id'].','; } if($str!=''){ $str=trim($str,','); 3、按照多个店铺排序 $model->orderByRaw('FIELD(user_id,'.$str.') desc'); }
注:关于field的用法
使用格式:filed(coulmn,str1,str2,str3…)
使用环境:需要在查询结果中根据某个字段的具体值来排序
使用举例:
tableA中有某一列columA,该列的值包含(0,1,2,3,4,5)
当前的需求为查询结果不包含3和5,且按2,1,0,4的规则进行排序 mysql的实现方式:select * from A where columA in(‘2’, ‘1’, ‘0’) order by FIELD(columA ,’2’,’1’, ‘0’)
如果要使用倒序排序请加desc,将按照倒序排列
详细参考: