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;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
}
|