| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358 | <?php/** * Created by PhpStorm. * User: hp * Date: 2017/12/2 * Time: 15:36 */namespace App\Modules\SendOrder\Services;use App\Modules\Book\Models\BookConfig;use App\Modules\Channel\Services\ChannelService;use App\Modules\SendOrder\Models\SendOrderForceDayStat;use App\Modules\Trade\Services\OrderService;use DB;use Redis;class SendOrderForceDayStatService{    //按书统计    static function getSendOrderDayStatsByBook($params)    {        return SendOrderForceDayStat::getSendOrderDayStatsByBook($params);    }    //生成    static function generateForceDayStat($date)    {        $end_send_time = date('Y-m-d H:i:s', strtotime($date) + 86400 - 1);        $fields = DB::raw("              send_order_id,              count(1) paid_num,              sum(price) recharge_amount,              count(distinct uid) pay_user_num        ");        //TODO 解除limit        $order_data = DB::table('orders')->select($fields)->where('status', 'PAID')->where('created_at','>=', $date)->where('created_at','<=', $end_send_time)->groupBy('send_order_id')->get();        $order_data_array = [];        if ($order_data) {            foreach ($order_data as $order) {                $order_data_array[$order->send_order_id] = $order;            }        }        $order_total_fields = DB::raw("                send_order_id,                count(1) order_num        ");        $order_total_data = DB::table('orders')->select($order_total_fields)->where('created_at','>=', $date)->where('created_at','<=', $end_send_time)->groupBy('send_order_id')->get();        $order_total_data_array = [];        if ($order_total_data) {            foreach ($order_total_data as $_order) {                $order_total_data_array[$_order->send_order_id] = $_order;            }        }        //注册用户        $register_fields = DB::raw("              send_order_id,              count(1) num        ");        $register_data = DB::table('users')->select($register_fields)->where('created_at','>=', $date)->where('created_at','<=', $end_send_time)->groupBy('send_order_id')->get();        $register_data_array = [];        if ($register_data) {            foreach ($register_data as $_register_data) {                $register_data_array[$_register_data->send_order_id] = $_register_data->num;            }        }        //满足有订单,有注册用户,有访问其中之一的派单才进行统计        $send_order_list_has_order = $order_total_data->pluck('send_order_id')->toArray();        $send_order_list_has_register = $register_data->pluck('send_order_id')->toArray();        $send_order_list_has_visit =  Redis::SMEMBERS('send_order'.$date);        $send_order_list = array_values(array_unique(array_merge($send_order_list_has_order,$send_order_list_has_register,$send_order_list_has_visit)));        foreach ($chunk_result = array_chunk($send_order_list, 500) as $send_order_ids)        {            $send_orders = DB::table('send_orders')->whereIn('id',$send_order_ids)->where('send_time', '>', '2019-01-01')->where('send_time', '<=', $end_send_time)->get();            $return_data = [];            foreach ($send_orders as $send_order) {                $data = [];                $data['send_order_id'] = $send_order->id;                $data['date'] = $date;                $data['create_time'] = $send_order->created_at;                $data['name'] = $send_order->name;                $data['charge_type'] = $send_order->charge_type;                if(isset($book_name_array[$send_order->book_id])){                    $book_name = $book_name_array[$send_order->book_id];                }else{                    $book_name =self::getBookNameByBid($send_order->book_id);                    $book_name_array[$send_order->book_id] = $book_name;                }                $data['book_name'] = $book_name;                $data['bid'] = $send_order->book_id;                $uv = SendOrderService::getUvInfo($send_order->id);                $pv = SendOrderService::getPvInfo($send_order->id);                $data['total_uv'] = isset($uv['total']) ? $uv['total'] : 0;                $data['uv'] = isset($uv[$date]) ? $uv[$date] : 0;                $data['total_pv'] = isset($pv['total']) ? $pv['total'] : 0;                $data['pv'] = isset($pv[$date]) ? $pv[$date] : 0;                $data['recharge_amount'] = isset($order_data_array[$send_order->id]) ? $order_data_array[$send_order->id]->recharge_amount : 0;                $data['paid_num'] = isset($order_data_array[$send_order->id]) ? $order_data_array[$send_order->id]->paid_num : 0;                $data['unpaid_num'] = isset($order_total_data_array[$send_order->id]) ? $order_total_data_array[$send_order->id]->order_num - $data['paid_num'] : 0;                $data['pay_user_num'] = isset($order_data_array[$send_order->id]) ? $order_data_array[$send_order->id]->pay_user_num : 0;                $data['distribution_channel_id'] = $send_order->distribution_channel_id;                $data['distribution_channel_name'] = ChannelService::getChannelCompanyNameById($send_order->distribution_channel_id);//ChannelService::getChannelNicknameById($send_order->distribution_channel_id);                $data['cost'] = $send_order->cost;                $data['send_time'] = $send_order->send_time;                $total_order_num = $data['unpaid_num'] + $data['paid_num'];                //强关用户数                $force_user_num = DB::table('force_subscribe_users')                    ->where('send_order_id', $send_order->id)                    ->where('created_at','>=',date('Y-m-d 00:00:00',strtotime($date)))                    ->where('created_at','<=',date('Y-m-d 23:59:59',strtotime($date)))                    ->count();                $data['force_user_num'] = $force_user_num;                //注册用户数                $data['register_user_num'] = isset($register_data_array[$send_order->id]) ? $register_data_array[$send_order->id] : 0;                //首充数据                if ($data['pay_user_num']) {                    $begin_time = $date;                    $end_time = date("Y-m-d", strtotime($date) + 86400);//                     $first_data = DB::select("select count(distinct uid) count,sum(price) amount from orders a where created_at>='{$begin_time}' and created_at<'{$end_time}' and send_order_id = '{$send_order->id}' and status ='PAID' and not exists (select uid from orders where a.uid = uid and created_at < '{$begin_time}' and status= 'PAID' limit 1)");                    $first_data = DB::select("select count(distinct uid) count,sum(price) amount from orders a where created_at>='{$begin_time}' and created_at<'{$end_time}' and send_order_id = '{$send_order->id}' and status ='PAID' and pay_type=1");                                        $data['first_recharge_user_num'] = (int)$first_data[0]->count;                    $data['first_recharge_amount'] = (float)$first_data[0]->amount;                } else {                    $data['first_recharge_user_num'] = 0;                    $data['first_recharge_amount'] = 0;                }                //12小时充值数据                if ($send_order->send_time) {                    $end_timestamp = min(strtotime($send_order->send_time) + 14 * 24 * 3600, strtotime($date) + 86400);                    $end_time = date("Y-m-d H:i:s", $end_timestamp);                    $data['recharge_amount_in_two_weeks'] = OrderService::getAmount(['send_order_id' => $send_order->id,  'end_time' => $end_time]);                    $end_timestamp = min(strtotime($send_order->send_time) + 12 * 3600, strtotime($date) + 86400);                    $end_time = date("Y-m-d H:i:s", $end_timestamp);                    $data['recharge_amount_in_half_day'] = OrderService::getAmount(['send_order_id' => $send_order->id, 'end_time' => $end_time]);                    //24小时                    $end_time = date("Y-m-d H:i:s", min(strtotime($send_order->send_time) + 24 * 3600,strtotime($date) + 86400));                    $data['recharge_amount_in_one_day'] = OrderService::getAmount(['send_order_id' => $send_order->id,  'end_time' => $end_time]);                    //3天                    $end_time = date("Y-m-d H:i:s", min(strtotime($send_order->send_time) + 3 * 24 * 3600,strtotime($date) + 86400));                    $data['recharge_amount_in_three_days'] = OrderService::getAmount(['send_order_id' => $send_order->id,  'end_time' => $end_time]);                } else {                    $data['recharge_amount_in_two_weeks'] = 0;                    $data['recharge_amount_in_half_day'] = 0;                    $data['recharge_amount_in_one_day'] = 0;                    $data['recharge_amount_in_three_days'] = 0;                }                //包年充值用户数                $data['year_recharge_user_num'] = $data['pay_user_num'] ? (int)DB::table('orders')->where('created_at','>=',date('Y-m-d 00:00:00',strtotime($date)))->where('created_at','<=',date('Y-m-d 23:59:59',strtotime($date)))->where('order_type', 'YEAR')->where('status', 'PAID')->distinct('uid')->where('send_order_id', $send_order->id)->count() : 0;                $data['ticket_recharge_user_num'] = $data['pay_user_num'] - $data['year_recharge_user_num'];                $data['year_paid_num'] = $data['pay_user_num'] ? (int)DB::table('orders')->where('created_at','>=',date('Y-m-d 00:00:00',strtotime($date)))->where('created_at','<=',date('Y-m-d 23:59:59',strtotime($date)))->where('order_type', 'YEAR')->where('status', 'PAID')->where('send_order_id', $send_order->id)->count() : 0;                $data['year_unpaid_num'] = $total_order_num ? (int)DB::table('orders')->where('created_at','>=',date('Y-m-d 00:00:00',strtotime($date)))->where('created_at','<=',date('Y-m-d 23:59:59',strtotime($date)))->where('order_type', 'YEAR')->where('status', 'UNPAID')->where('send_order_id', $send_order->id)->count() : 0;                SendOrderForceDayStat::generateForceDayStat($data);                $return_data[] = $data;            }            SendOrderStatService::generateStatsByDayStats($return_data,$date);            //});        }        //return $return_data;    }    static function generateSingleForceDayStat($send_order_id,$date)    {        $end_send_time = date('Y-m-d H:i:s', strtotime($date) + 86400 - 1);        $fields = DB::raw("              send_order_id,              count(1) paid_num,              sum(price) recharge_amount,              count(distinct uid) pay_user_num        ");        //TODO 解除limit        $order_data = DB::table('orders')->select($fields)            ->where('status', 'PAID')->where('created_at','>=', $date)            ->where('send_order_id',$send_order_id)            ->where('created_at','<=', $end_send_time)->groupBy('send_order_id')->get();        $order_data_array = [];        if ($order_data) {            foreach ($order_data as $order) {                $order_data_array[$order->send_order_id] = $order;            }        }        $order_total_fields = DB::raw("                send_order_id,                count(1) order_num        ");        $order_total_data = DB::table('orders')->select($order_total_fields)            ->where('created_at','>=', $date)            ->where('created_at','<=', $end_send_time)            ->where('send_order_id',$send_order_id)            ->groupBy('send_order_id')->get();        $order_total_data_array = [];        if ($order_total_data) {            foreach ($order_total_data as $_order) {                $order_total_data_array[$_order->send_order_id] = $_order;            }        }        //注册用户        $register_fields = DB::raw("              send_order_id,              count(1) num        ");        $register_data = DB::table('users')->select($register_fields)            ->where('created_at','>=', $date)            ->where('created_at','<=', $end_send_time)            ->where('send_order_id',$send_order_id)            ->groupBy('send_order_id')->get();        $register_data_array = [];        if ($register_data) {            foreach ($register_data as $_register_data) {                $register_data_array[$_register_data->send_order_id] = $_register_data->num;            }        }        DB::table('send_orders')->where('is_enable', 1)            //->where('send_time', '<=', $end_send_time)            ->where('id', '<=', $send_order_id)            ->orderBy('id')->chunk(1000,function($send_orders) use($date,$order_data_array,$order_total_data_array,$register_data_array){//        $send_orders = SendOrderService::search(compact('end_send_time'), true);            $return_data = [];            foreach ($send_orders as $send_order) {                $data = [];                $data['send_order_id'] = $send_order->id;                $data['date'] = $date;                $data['create_time'] = $send_order->created_at;                $data['name'] = $send_order->name;                $data['charge_type'] = $send_order->charge_type;                if(isset($book_name_array[$send_order->book_id])){                    $book_name = $book_name_array[$send_order->book_id];                }else{                    $book_name =self::getBookNameByBid($send_order->book_id);                    $book_name_array[$send_order->book_id] = $book_name;                }                $data['book_name'] = $book_name;                $data['bid'] = $send_order->book_id;                $uv = SendOrderService::getUvInfo($send_order->id);                $pv = SendOrderService::getPvInfo($send_order->id);                $data['total_uv'] = isset($uv['total']) ? $uv['total'] : 0;                $data['uv'] = isset($uv[$date]) ? $uv[$date] : 0;                $data['total_pv'] = isset($pv['total']) ? $pv['total'] : 0;                $data['pv'] = isset($pv[$date]) ? $pv[$date] : 0;                $data['recharge_amount'] = isset($order_data_array[$send_order->id]) ? $order_data_array[$send_order->id]->recharge_amount : 0;                $data['paid_num'] = isset($order_data_array[$send_order->id]) ? $order_data_array[$send_order->id]->paid_num : 0;                $data['unpaid_num'] = isset($order_total_data_array[$send_order->id]) ? $order_total_data_array[$send_order->id]->order_num - $data['paid_num'] : 0;                $data['pay_user_num'] = isset($order_data_array[$send_order->id]) ? $order_data_array[$send_order->id]->pay_user_num : 0;                $data['distribution_channel_id'] = $send_order->distribution_channel_id;                $data['distribution_channel_name'] = ChannelService::getChannelCompanyNameById($send_order->distribution_channel_id);//ChannelService::getChannelNicknameById($send_order->distribution_channel_id);                $data['cost'] = $send_order->cost;                $data['send_time'] = $send_order->send_time;                $total_order_num = $data['unpaid_num'] + $data['paid_num'];                //强关用户数                $force_user_num = DB::table('force_subscribe_users')                    ->where('send_order_id', $send_order->id)                    ->where('created_at','>=',date('Y-m-d 00:00:00',strtotime($date)))                    ->where('created_at','<=',date('Y-m-d 23:59:59',strtotime($date)))                    ->count();                $data['force_user_num'] = $force_user_num;                //注册用户数                $data['register_user_num'] = isset($register_data_array[$send_order->id]) ? $register_data_array[$send_order->id] : 0;                //首充数据                if ($data['pay_user_num']) {                    $begin_time = $date;                    $end_time = date("Y-m-d", strtotime($date) + 86400);                    $first_data = DB::select("select count(distinct uid) count,sum(price) amount from orders a where created_at>='{$begin_time}' and created_at<'{$end_time}' and send_order_id = '{$send_order->id}' and status ='PAID' and not exists (select uid from orders where a.uid = uid and created_at < '{$begin_time}' and status= 'PAID' limit 1)");                    $data['first_recharge_user_num'] = (int)$first_data[0]->count;                    $data['first_recharge_amount'] = (float)$first_data[0]->amount;                } else {                    $data['first_recharge_user_num'] = 0;                    $data['first_recharge_amount'] = 0;                }                //12小时充值数据                if ($send_order->send_time) {                    $end_timestamp = min(strtotime($send_order->send_time) + 7 * 24 * 3600, strtotime($date) + 86400);                    $end_time = date("Y-m-d H:i:s", $end_timestamp);                    $data['recharge_amount_in_two_weeks'] = OrderService::getAmount(['send_order_id' => $send_order->id,  'end_time' => $end_time]);                    $end_timestamp = min(strtotime($send_order->send_time) + 12 * 3600, strtotime($date) + 86400);                    $end_time = date("Y-m-d H:i:s", $end_timestamp);                    $data['recharge_amount_in_half_day'] = OrderService::getAmount(['send_order_id' => $send_order->id, 'end_time' => $end_time]);                    //24小时                    $end_time = date("Y-m-d H:i:s", min(strtotime($send_order->send_time) + 24 * 3600,strtotime($date) + 86400));                    $data['recharge_amount_in_one_day'] = OrderService::getAmount(['send_order_id' => $send_order->id,  'end_time' => $end_time]);                    //3天                    $end_time = date("Y-m-d H:i:s", min(strtotime($send_order->send_time) + 3 * 24 * 3600,strtotime($date) + 86400));                    $data['recharge_amount_in_three_days'] = OrderService::getAmount(['send_order_id' => $send_order->id,  'end_time' => $end_time]);                } else {                    $data['recharge_amount_in_two_weeks'] = 0;                    $data['recharge_amount_in_half_day'] = 0;                    $data['recharge_amount_in_one_day'] = 0;                    $data['recharge_amount_in_three_days'] = 0;                }                //包年充值用户数                $data['year_recharge_user_num'] = $data['pay_user_num'] ? (int)DB::table('orders')->where('created_at','>=',date('Y-m-d 00:00:00',strtotime($date)))->where('created_at','<=',date('Y-m-d 23:59:59',strtotime($date)))->where('order_type', 'YEAR')->where('status', 'PAID')->distinct('uid')->where('send_order_id', $send_order->id)->count() : 0;                $data['ticket_recharge_user_num'] = $data['pay_user_num'] - $data['year_recharge_user_num'];                $data['year_paid_num'] = $data['pay_user_num'] ? (int)DB::table('orders')->where('created_at','>=',date('Y-m-d 00:00:00',strtotime($date)))->where('created_at','<=',date('Y-m-d 23:59:59',strtotime($date)))->where('order_type', 'YEAR')->where('status', 'PAID')->where('send_order_id', $send_order->id)->count() : 0;                $data['year_unpaid_num'] = $total_order_num ? (int)DB::table('orders')->where('created_at','>=',date('Y-m-d 00:00:00',strtotime($date)))->where('created_at','<=',date('Y-m-d 23:59:59',strtotime($date)))->where('order_type', 'YEAR')->where('status', 'UNPAID')->where('send_order_id', $send_order->id)->count() : 0;                SendOrderForceDayStat::generateForceDayStat($data);                $return_data[] = $data;            }            SendOrderStatService::generateStatsByDayStats($return_data,$date);        });        //return $return_data;    }    /**     * 管理后台获历史取派单信息     * @param $params 字段列表     * @param string $isAll 是否获取所有     * @return mixed     */    static function getHistorySendOrders($params = [], $is_all = false)    {        return SendOrderForceDayStat::getHistorySendOrders($params, $is_all);    }    public static function getSendOrdersRechargeDetail($distribution_channels) {        SendOrderForceDayStat::getBookSendOrdersRechargeStats();    }    private static function getBookNameByBid($bid){        $book = BookConfig::where('bid',$bid)->select('book_name')->first();        if($book)            return $book->book_name;        return 'unknown';    }    public static function getSendOrdersDayStatsByBid($date) {        $sql = "select bid, book_name,sum(recharge_amount) as rechareg_amount,sum(uv) uv,                   sum(pv) pv,sum(paid_num) success_order_num,book_categories.pid as type,date,                   sum(unpaid_num) as unpaid_num,sum(register_user_num) as register_user_num,NOW() as created_at,NOW() as updated_at                    from send_orders_force_day_stats force index(date_bid)                    inner join books on books.id=send_orders_force_day_stats.bid                    INNER JOIN book_categories ON book_categories.id=books.category_id                     where total_uv > 20 and date ='{$date}'										 group by bid";        return \DB::select($sql);    }}
 |