97 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			PHP
		
	
	
		
		
			
		
	
	
			97 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			PHP
		
	
	
|  | <?php | |||
|  | // +----------------------------------------------------------------------
 | |||
|  | // | likeshop开源商城系统
 | |||
|  | // +----------------------------------------------------------------------
 | |||
|  | // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
 | |||
|  | // | gitee下载:https://gitee.com/likeshop_gitee
 | |||
|  | // | github下载:https://github.com/likeshop-github
 | |||
|  | // | 访问官网:https://www.likeshop.cn
 | |||
|  | // | 访问社区:https://home.likeshop.cn
 | |||
|  | // | 访问手册:http://doc.likeshop.cn
 | |||
|  | // | 微信公众号:likeshop技术社区
 | |||
|  | // | likeshop系列产品在gitee、github等公开渠道开源版本可免费商用,未经许可不能去除前后端官方版权标识
 | |||
|  | // |  likeshop系列产品收费版本务必购买商业授权,购买去版权授权后,方可去除前后端官方版权标识
 | |||
|  | // | 禁止对系统程序代码以任何目的,任何形式的再发布
 | |||
|  | // | likeshop团队版权所有并拥有最终解释权
 | |||
|  | // +----------------------------------------------------------------------
 | |||
|  | // | author: likeshop.cn.team
 | |||
|  | // +----------------------------------------------------------------------
 | |||
|  | 
 | |||
|  | namespace app\common\command; | |||
|  | 
 | |||
|  | use app\common\enum\PayEnum; | |||
|  | use app\common\model\distribution\DistributionOrderGoods; | |||
|  | use app\common\model\Pay; | |||
|  | use app\common\model\user\User; | |||
|  | use think\console\Command; | |||
|  | use think\console\Input; | |||
|  | use think\console\Output; | |||
|  | use app\common\model\order\Order; | |||
|  | use think\facade\Log; | |||
|  | 
 | |||
|  | class UserDistribution extends Command | |||
|  | { | |||
|  |     protected function configure() | |||
|  |     { | |||
|  |         $this->setName('user_distribution') | |||
|  |             ->setDescription('更新会员分销信息'); | |||
|  |     } | |||
|  | 
 | |||
|  |     protected function execute(Input $input, Output $output) | |||
|  |     { | |||
|  |         try { | |||
|  |             $userModel = new User(); | |||
|  |             $users = $userModel->alias('u') | |||
|  |                 ->field('d.*') | |||
|  |                 ->join('user_distribution d', 'd.user_id = u.id') | |||
|  |                 ->where(['u.del' => 0]) | |||
|  |                 ->select()->toArray(); | |||
|  | 
 | |||
|  |             if (!$users) { | |||
|  |                 return true; | |||
|  |             } | |||
|  | 
 | |||
|  |             foreach ($users as $user) { | |||
|  |                 //粉丝数量
 | |||
|  |                 $where1 = [ | |||
|  |                     ['first_leader', '=', $user['user_id']], | |||
|  |                 ]; | |||
|  |                 $where2 = [ | |||
|  |                     ['second_leader', '=', $user['user_id']], | |||
|  |                 ]; | |||
|  |                 $fans = User::whereOr([$where1, $where2])->count(); | |||
|  | 
 | |||
|  |                 //分销订单信息
 | |||
|  |                 $distribution = DistributionOrderGoods::where(['user_id' => $user['user_id']]) | |||
|  |                     ->field('sum(money) as money, count(id) as order_num') | |||
|  |                     ->find(); | |||
|  | 
 | |||
|  |                 //订单信息
 | |||
|  |                 $order = Order::where([ | |||
|  |                     'user_id' => $user['user_id'], | |||
|  |                     'pay_status' => PayEnum::ISPAID, | |||
|  |                     'refund_status' => 0 | |||
|  |                 ]) | |||
|  |                 ->field('sum(order_amount) as order_amount, count(id) as order_num') | |||
|  |                 ->find(); | |||
|  | 
 | |||
|  |                 $data = [ | |||
|  |                     'distribution_order_num' => $distribution['order_num'] ?? 0, | |||
|  |                     'distribution_money' => $distribution['money'] ?? 0, | |||
|  |                     'order_num' => $order['order_num'] ?? 0, | |||
|  |                     'order_amount' => $order['order_amount'] ?? 0, | |||
|  |                     'fans' => $fans, | |||
|  |                     'update_time' => time(), | |||
|  |                 ]; | |||
|  | 
 | |||
|  |                 //更新会员分销信息表
 | |||
|  |                 \app\common\model\user\UserDistribution::where('user_id', $user['user_id'])->update($data); | |||
|  |             } | |||
|  |             return true; | |||
|  |         } catch (\Exception $e) { | |||
|  |             Log::write('自动更新会员分销信息异常:'.$e->getMessage()); | |||
|  |             return false; | |||
|  |         } | |||
|  |     } | |||
|  | 
 | |||
|  | } |