电子商务网站中店铺按销量的排序

 

使用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,将按照倒序排列

 

详细参考:https://www.cnblogs.com/chenhaoyu/p/9771012.html

转载于:https://www.cnblogs.com/fogwang/p/10874759.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值