12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- <?php
- namespace App\Console\Commands;
- use App\Models\Order;
- use App\Models\OrderOverviewModel;
- use App\Models\Project;
- use Illuminate\Console\Command;
- use Illuminate\Support\Facades\Log;
- class GetOrdersOverview extends Command
- {
- /**
- * The name and signature of the console command.
- *
- * @var string
- */
- protected $name = 'ordersOverview';
- protected $signature = 'get:orders_overview';
- /**
- * The console command description.
- *
- * @var string
- */
- protected $description = '获取每月订单总览数据';
- /**
- * Create a new command instance.
- *
- * @return void
- */
- public function __construct()
- {
- parent::__construct();
- }
- /**
- * Execute the console command.
- *
- * @return mixed
- */
- public function handle()
- {
- //获取每月一号的上一个月的时间
- $time = strtotime('-1 month');
- $before_date = date('Y-m-01 00:00:00',$time);
- $date = date('Y-m-01 00:00:00');
- //获取到所有的通过审核的项目id
- $project_ids = Project::where('active',1)->pluck('id')->toArray();
- foreach ($project_ids as $project_id)
- {
- $data = [
- 'total_price' => 0,
- ];
- //获取到项目内已完成并且更新时间在上个月的订单id的数组
- $order_arr = Order::where('project_id',$project_id)
- ->where('status',3)
- ->where('type',1)
- ->where('updated_at','>=',$before_date)
- ->where('updated_at','<',$date)
- ->get(['id','money','project_id'])->toArray();
- //如果订单数据为空那就添加一个空的数据条目到数据总览中
- if (empty($order_arr))
- {
- Log::info(Project::where('id',$project_id)->value('name').'项目'.date('Y-m',$time).'的数据总金额为空,默认写入空数据');
- $data['order_sn'] = Order::createOrderNumber();
- $data['date'] = $before_date;
- $data['project_id'] = $project_id;
- $data['status'] = 0;
- $data['confirmation_user_id'] = Project::where('id',$project_id)->value('user_id');
- $data['created_at'] = date('Y-m-d H:i:s',time());
- $data['updated_at'] = date('Y-m-d H:i:s',time());
- OrderOverviewModel::insert($data);
- }else
- {
- Log::info(Project::where('id',$project_id)->value('name').'项目'.date('Y-m',$time).'的数据写入');
- $num_arr = array_column($order_arr,'money');
- $total = array_sum($num_arr);
- $data['order_sn'] = Order::createOrderNumber();
- $data['date'] = $before_date;
- $data['project_id'] = $project_id;
- $data['status'] = 0;
- $data['confirmation_user_id'] = Project::where('id',$project_id)->value('user_id');
- $data['total_price'] = $total;
- $data['created_at'] = date('Y-m-d H:i:s',time());
- $data['updated_at'] = date('Y-m-d H:i:s',time());
- OrderOverviewModel::insert($data);
- }
- }
- }
- }
|