updateUserLevel.php 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  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. protected $signature = 'updateUserLevel';
  10. protected $description = '更新用户等级';
  11. public function __construct() {
  12. parent::__construct();
  13. }
  14. public function handle() {
  15. Log::info('----------------------------【用户等级升级】开始----------------------------');
  16. // 预设level 0
  17. $users = User::query()->where('level', '<>', 0)->get();
  18. foreach($users as $user){
  19. User::query()->whereId($user->id)->update(['level' => 0]);
  20. }
  21. // 获取商品列表,取新等级
  22. $goodList = Goods::query()->where('level', '<>', 0)->whereType(2)->get();
  23. // 取生效的套餐
  24. $orderList = Order::query()->whereIn('goods_id', $goodList->pluck('id')->toArray())->whereStatus(2)->whereIsExpire(0)->get();
  25. foreach($orderList as $order){
  26. $ret = User::query()->whereId($order->user_id)->update(['level' => $order->goods->level]);
  27. if($ret){
  28. Log::info('用户: '.$order->user->id.', 按照订单'.$order->id.' 等级为'.$order->goods->level);
  29. }else{
  30. Log::error('用户: '.$order->user->id.' 等级更新失败!');
  31. }
  32. }
  33. Log::info('----------------------------【用户等级升级】结束----------------------------');
  34. }
  35. }