GoodsRanking.php 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | 萤火商城系统 [ 致力于通过产品和服务,帮助商家高效化开拓市场 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2017~2024 https://www.yiovo.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed 这不是一个自由软件,不允许对程序代码以任何形式任何目的的再发行
  8. // +----------------------------------------------------------------------
  9. // | Author: 萤火科技 <admin@yiovo.com>
  10. // +----------------------------------------------------------------------
  11. declare (strict_types=1);
  12. namespace app\store\service\statistics\data;
  13. use app\common\service\BaseService;
  14. use app\store\model\OrderGoods as OrderGoodsModel;
  15. use app\common\enum\order\OrderStatus as OrderStatusEnum;
  16. use app\common\enum\order\PayStatus as OrderPayStatusEnum;
  17. /**
  18. * 数据统计-商品销售榜
  19. * Class GoodsRanking
  20. * @package app\store\service\statistics\data
  21. */
  22. class GoodsRanking extends BaseService
  23. {
  24. /**
  25. * 商品销售榜
  26. * @return mixed
  27. */
  28. public function getGoodsRanking()
  29. {
  30. return (new OrderGoodsModel)->alias('o_goods')
  31. ->field([
  32. 'goods_id',
  33. // 这里采用聚合函数获取goods_name, 因为mysql5.7使用group的报错问题
  34. 'MAX(goods_name) AS goods_name',
  35. 'SUM(total_pay_price) AS sales_volume',
  36. 'SUM(total_num) AS total_sales_num'
  37. ])
  38. ->join('order', 'order.order_id = o_goods.order_id')
  39. ->where('order.pay_status', '=', OrderPayStatusEnum::SUCCESS)
  40. ->where('order.order_status', '<>', OrderStatusEnum::CANCELLED)
  41. // 这里如果写入goods_name的话,会出现同商品ID不同name的数据
  42. ->group('goods_id')
  43. // order:此处按总销售额排序,如需按销量改为total_sales_num
  44. ->order(['sales_volume' => 'DESC'])
  45. ->limit(10)
  46. ->select();
  47. }
  48. }