Laravel 代理收益排行榜

创建了一个收入表

sql 复制代码
CREATE TABLE `income_logs` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `order_id` int(11) NOT NULL COMMENT '订单ID',
  `type` int(11) NOT NULL DEFAULT '0' COMMENT ' 类型 0 支出 1收入',
  `user_id` int(11) NOT NULL COMMENT '消费者用户',
  `price` decimal(10,2) NOT NULL COMMENT '收益金额',
  `agent_user_id` int(11) NOT NULL COMMENT '代理用户ID',
  `updated_at` timestamp NULL DEFAULT NULL COMMENT '更新时间',
  `created_at` timestamp NULL DEFAULT NULL COMMENT '创建时间',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='收益明细';

每次有利润的时候创建一条代理收益记录,我们做月排行榜的时候不好计算,下面是计算月排行榜的代码

php 复制代码
$startOfMonth = Carbon::now()->startOfMonth(); // 当前月的1日
$endOfMonth = Carbon::now()->endOfMonth(); // 当前月的最后一天

$data['list'] = Income::select('agent_user_id', DB::raw('SUM(price) as earnings'))
    ->whereBetween('created_at', [$startOfMonth, $endOfMonth]) // 指定日期范围
    ->groupBy('agent_user_id') // 按代理用户 ID 分组
    ->having(DB::raw('SUM(price)'), '>', 0) // 只显示收益大于0的数据
    ->orderBy('earnings', 'desc') // 按 earnings 降序排列
    ->take(50) // 限制返回结果数量
    ->get();

/* 补充用户信息 */
foreach ($data['list'] as $item) {
    $user = User::where('id', $item['agent_user_id'])->first();
    $item['avatar'] = $user['avatar'];
    $item['id'] = $item['agent_user_id'];
    $item['username'] = $user['username'];
    $item['is_vip'] = $user['is_vip'];
}
相关推荐
加班是不可能的,除非双倍日工资4 小时前
css预编译器实现星空背景图
前端·css·vue3
桦说编程4 小时前
Java 中如何创建不可变类型
java·后端·函数式编程
lifallen4 小时前
Java Stream sort算子实现:SortedOps
java·开发语言
IT毕设实战小研4 小时前
基于Spring Boot 4s店车辆管理系统 租车管理系统 停车位管理系统 智慧车辆管理系统
java·开发语言·spring boot·后端·spring·毕业设计·课程设计
wyiyiyi4 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
没有bug.的程序员5 小时前
JVM 总览与运行原理:深入Java虚拟机的核心引擎
java·jvm·python·虚拟机
gnip5 小时前
vite和webpack打包结构控制
前端·javascript
excel5 小时前
在二维 Canvas 中模拟三角形绕 X、Y 轴旋转
前端
甄超锋5 小时前
Java ArrayList的介绍及用法
java·windows·spring boot·python·spring·spring cloud·tomcat
阿华的代码王国5 小时前
【Android】RecyclerView复用CheckBox的异常状态
android·xml·java·前端·后端