updateUserLevel.php 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. <?php
  2. namespace App\Console\Commands;
  3. use App\Models\Goods;
  4. use App\Models\Order;
  5. use App\Models\User;
  6. use Illuminate\Console\Command;
  7. use Log;
  8. class updateUserLevel extends Command
  9. {
  10. protected $signature = 'updateUserLevel';
  11. protected $description = '更新用户等级';
  12. public function handle(): void
  13. {
  14. Log::info(
  15. '----------------------------【用户等级升级】开始----------------------------'
  16. );
  17. // 预设level 0
  18. User::where('level', '<>', 0)->update(['level' => 0]);
  19. // 获取商品列表,取新等级
  20. $goodsLevel = Goods::type(2)
  21. ->where('level', '<>', 0)
  22. ->pluck('id')
  23. ->toArray();
  24. // 取生效的套餐
  25. $orderList = Order::active()->with('goods')->whereIn(
  26. 'goods_id',
  27. $goodsLevel
  28. )->get();
  29. foreach ($orderList as $order) {
  30. $ret = $order->user->update(['level' => $order->goods->level]);
  31. if ($ret) {
  32. Log::info(
  33. '用户: ' . $order->user_id . ', 按照订单' . $order->id . ' 等级为' . $order->goods->level
  34. );
  35. } else {
  36. Log::error('用户: ' . $order->user_id . ' 等级更新失败!');
  37. }
  38. }
  39. Log::info(
  40. '----------------------------【用户等级升级】结束----------------------------'
  41. );
  42. }
  43. }