SendOrderStatService.php 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: hp
  5. * Date: 2017/12/2
  6. * Time: 15:36
  7. */
  8. namespace App\Modules\SendOrder\Services;
  9. use App\Modules\Channel\Services\ChannelService;
  10. use App\Modules\SendOrder\Models\SendOrderStat;
  11. use DB;
  12. class SendOrderStatService
  13. {
  14. //获取派单obj
  15. static function search($params = [], $isAll = false)
  16. {
  17. return SendOrderStat::search($params, $isAll);
  18. }
  19. /**
  20. * 获取派单汇总统计信息
  21. * @param $params 字段列表
  22. * @param string $isAll 是否获取所有
  23. * @return mixed
  24. */
  25. static function getSendOrderStats($params = [], $is_all = false)
  26. {
  27. return SendOrderStat::getSendOrderStats($params, $is_all);
  28. }
  29. //生成统计
  30. static function generateStat()
  31. {
  32. $fields = DB::raw("send_order_id,max(date) max_date,book_name,bid,sum(uv) sum_uv,sum(pv) sum_pv,sum(recharge_amount) sum_recharge_amount,sum(paid_num) sum_paid_num,sum(unpaid_num) sum_unpaid_num,
  33. distribution_channel_id,max(recharge_amount_in_half_day) max_recharge_amount_in_half_day,max(recharge_amount_in_one_day) max_recharge_amount_in_one_day,max(recharge_amount_in_two_weeks) max_recharge_amount_in_two_weeks,
  34. max(recharge_amount_in_three_days) max_recharge_amount_in_three_days,max(recharge_amount_in_one_day) max_recharge_amount_in_one_day,send_time,cost,sum(year_recharge_user_num) sum_year_recharge_user_num,
  35. sum(ticket_recharge_user_num) sum_ticket_recharge_user_num,sum(first_recharge_amount) sum_first_recharge_amount, sum(first_recharge_user_num) sum_first_recharge_user_num,sum(year_paid_num) sum_year_paid_num,
  36. sum(year_unpaid_num) sum_year_unpaid_num,sum(pay_user_num) sum_pay_user_num,sum(force_user_num) sum_force_user_num,sum(register_user_num) sum_register_user_num,distribution_channel_name,charge_type,name,create_time");
  37. $stats = DB::table('send_orders_force_day_stats')->select($fields)->groupBy('send_order_id')->get();
  38. foreach ($stats as $stat) {
  39. $end_time = date("Y-m-d", strtotime($stat->max_date) + 86400);
  40. $data = [];
  41. $data['send_order_id'] = $stat->send_order_id;
  42. $data['book_name'] = $stat->book_name;
  43. $data['bid'] = $stat->bid;
  44. $data['uv'] = $stat->sum_uv;
  45. $data['pv'] = $stat->sum_pv;
  46. $data['recharge_amount'] = $stat->sum_recharge_amount;
  47. $data['paid_num'] = $stat->sum_paid_num;
  48. $data['unpaid_num'] = $stat->sum_unpaid_num;
  49. $data['distribution_channel_id'] = $stat->distribution_channel_id;
  50. $data['recharge_amount_in_half_day'] = $stat->max_recharge_amount_in_half_day;
  51. $data['recharge_amount_in_one_day'] = $stat->max_recharge_amount_in_one_day;
  52. $data['recharge_amount_in_two_weeks'] = $stat->max_recharge_amount_in_two_weeks;
  53. $data['recharge_amount_in_three_days'] = $stat->max_recharge_amount_in_three_days;
  54. $data['recharge_amount_in_one_day'] = $stat->max_recharge_amount_in_one_day;
  55. $data['send_time'] = $stat->send_time;
  56. $data['cost'] = $stat->cost;
  57. //付费用户数
  58. $data['year_recharge_user_num'] = (int) DB::table('orders')
  59. ->where('send_order_id', $stat->send_order_id)
  60. ->distinct('uid')->where('order_type', 'YEAR')
  61. ->where('created_at', '<', $end_time)
  62. ->where('status', 'PAID')
  63. ->count();
  64. $data['ticket_recharge_user_num'] = (int) DB::table('orders')->where('send_order_id', $stat->send_order_id)->distinct('uid')->where('order_type', 'RECHARGE')->where('created_at', '<', $end_time)->where('status', 'PAID')->count();
  65. $data['pay_user_num'] = (int) DB::table('orders')->where('send_order_id', $stat->send_order_id)->distinct('uid')->where('status', 'PAID')->where('created_at', '<', $end_time)->count();
  66. $data['first_recharge_amount'] = $stat->sum_first_recharge_amount;
  67. $data['first_recharge_user_num'] = $stat->sum_first_recharge_user_num;
  68. $data['year_paid_num'] = $stat->sum_year_paid_num;
  69. $data['year_unpaid_num'] = $stat->sum_year_unpaid_num;
  70. $data['force_user_num'] = $stat->sum_force_user_num;
  71. $data['register_user_num'] = $stat->sum_register_user_num;
  72. $data['distribution_channel_name'] = $stat->distribution_channel_name;
  73. $data['charge_type'] = $stat->charge_type;
  74. $data['name'] = $stat->name;
  75. $data['create_time'] = $stat->create_time;
  76. SendOrderStat::generateStat($data);
  77. }
  78. }
  79. //获取派单
  80. static function getList($params = [], $is_all = false)
  81. {
  82. return SendOrderStat::getList($params, $is_all);
  83. }
  84. //获取派单obj
  85. static function getObj($params = [])
  86. {
  87. return SendOrderStat::getObj($params);
  88. }
  89. static function generateStatsByDayStats($data, $date)
  90. {
  91. //$yesterday = date('Y-m-d',strtotime($date.' -1 day'));
  92. //$save_data = [];
  93. foreach ($data as $key => $item) {
  94. $yest_data = SendOrderStat::where('send_order_id', $item['send_order_id'])->first();
  95. $end_time = date('Y-m-d', strtotime($date) + 86400);
  96. $save_data = array();
  97. if ($yest_data) {
  98. $save_data = array(
  99. 'send_order_id' => $yest_data->send_order_id,
  100. 'book_name' => $yest_data->book_name,
  101. 'bid' => $yest_data->bid,
  102. 'uv' => $item['uv'] + $yest_data->uv,
  103. 'pv' => $item['pv'] + $yest_data->pv,
  104. 'recharge_amount' => $item['recharge_amount'] + $yest_data->recharge_amount,
  105. 'paid_num' => $item['paid_num'] + $yest_data->paid_num,
  106. 'unpaid_num' => $item['unpaid_num'] + $yest_data->unpaid_num,
  107. 'distribution_channel_id' => $item['distribution_channel_id'],
  108. 'recharge_amount_in_half_day' => ($item['recharge_amount_in_half_day'] >= $yest_data->recharge_amount_in_half_day) ? $item['recharge_amount_in_half_day'] : $yest_data->recharge_amount_in_half_day,
  109. 'recharge_amount_in_one_day' => ($item['recharge_amount_in_one_day'] >= $yest_data->recharge_amount_in_one_day) ? $item['recharge_amount_in_one_day'] : $yest_data->recharge_amount_in_one_day,
  110. 'recharge_amount_in_two_weeks' => ($item['recharge_amount_in_two_weeks'] >= $yest_data->recharge_amount_in_two_weeks) ? $item['recharge_amount_in_two_weeks'] : $yest_data->recharge_amount_in_two_weeks,
  111. 'recharge_amount_in_three_days' => ($item['recharge_amount_in_three_days'] >= $yest_data->recharge_amount_in_three_days) ? $item['recharge_amount_in_three_days'] : $yest_data->recharge_amount_in_three_days,
  112. 'send_time' => $item['send_time'],
  113. 'cost' => $item['cost'],
  114. //付费用户数
  115. 'year_recharge_user_num' => (int) DB::table('orders')
  116. ->where('send_order_id', $item['send_order_id'])
  117. ->select(DB::raw('distinct uid'))
  118. ->where('order_type', 'YEAR')
  119. ->where('created_at', '<', $end_time)
  120. ->where('status', 'PAID')
  121. ->get()
  122. ->count(),
  123. 'ticket_recharge_user_num' => (int) DB::table('orders')
  124. ->where('send_order_id', $item['send_order_id'])
  125. ->select(DB::raw('distinct uid'))
  126. ->where('order_type', 'RECHARGE')
  127. ->where('created_at', '<', $end_time)
  128. ->where('status', 'PAID')
  129. ->get()
  130. ->count(),
  131. 'pay_user_num' => (int) DB::table('orders')
  132. ->where('send_order_id', $item['send_order_id'])
  133. ->select(DB::raw('distinct uid'))
  134. ->where('status', 'PAID')
  135. ->where('created_at', '<', $end_time)
  136. ->get()
  137. ->count(),
  138. 'first_recharge_amount' => $item['first_recharge_amount'] + $yest_data->first_recharge_amount,
  139. 'first_recharge_user_num' => $item['first_recharge_user_num'] + $yest_data->first_recharge_user_num,
  140. 'year_paid_num' => $item['year_paid_num'] + $yest_data->year_paid_num,
  141. 'year_unpaid_num' => $item['year_unpaid_num'] + $yest_data->year_unpaid_num,
  142. 'force_user_num' => $item['force_user_num'] + $yest_data->force_user_num,
  143. 'register_user_num' => $item['register_user_num'] + $yest_data->register_user_num,
  144. 'distribution_channel_name' => $item['distribution_channel_name'],
  145. 'charge_type' => $item['charge_type'],
  146. 'name' => $item['name'],
  147. 'create_time' => $item['create_time']
  148. );
  149. } else {
  150. $save_data = array(
  151. 'send_order_id' => $item['send_order_id'],
  152. 'book_name' => $item['book_name'],
  153. 'bid' => $item['bid'],
  154. 'uv' => $item['uv'],
  155. 'pv' => $item['pv'],
  156. 'recharge_amount' => $item['recharge_amount'],
  157. 'paid_num' => $item['paid_num'],
  158. 'unpaid_num' => $item['unpaid_num'],
  159. 'distribution_channel_id' => $item['distribution_channel_id'],
  160. 'recharge_amount_in_half_day' => $item['recharge_amount_in_half_day'],
  161. 'recharge_amount_in_one_day' => $item['recharge_amount_in_one_day'],
  162. 'recharge_amount_in_two_weeks' => $item['recharge_amount_in_two_weeks'],
  163. 'recharge_amount_in_three_days' => $item['recharge_amount_in_three_days'],
  164. 'send_time' => $item['send_time'],
  165. 'cost' => $item['cost'],
  166. //付费用户数
  167. 'year_recharge_user_num' => (int) DB::table('orders')
  168. ->where('send_order_id', $item['send_order_id'])
  169. ->select(DB::raw('distinct uid'))
  170. ->where('order_type', 'YEAR')
  171. ->where('created_at', '<', $end_time)
  172. ->where('status', 'PAID')
  173. ->get()
  174. ->count(),
  175. 'ticket_recharge_user_num' => (int) DB::table('orders')
  176. ->where('send_order_id', $item['send_order_id'])
  177. ->select(DB::raw('distinct uid'))
  178. ->where('order_type', 'RECHARGE')
  179. ->where('created_at', '<', $end_time)
  180. ->where('status', 'PAID')
  181. ->get()
  182. ->count(),
  183. 'pay_user_num' => (int) DB::table('orders')
  184. ->where('send_order_id', $item['send_order_id'])
  185. ->select(DB::raw('distinct uid'))
  186. ->where('status', 'PAID')
  187. ->where('created_at', '<', $end_time)
  188. ->get()
  189. ->count(),
  190. 'first_recharge_amount' => $item['first_recharge_amount'],
  191. 'first_recharge_user_num' => $item['first_recharge_user_num'],
  192. 'year_paid_num' => $item['year_paid_num'],
  193. 'year_unpaid_num' => $item['year_unpaid_num'],
  194. 'force_user_num' => $item['force_user_num'],
  195. 'register_user_num' => $item['register_user_num'],
  196. 'distribution_channel_name' => ChannelService::getChannelCompanyNameById($item['distribution_channel_id']),
  197. 'charge_type' => $item['charge_type'],
  198. 'name' => $item['name'],
  199. 'create_time' => $item['create_time']
  200. );
  201. }
  202. SendOrderStat::updateOrCreate(['send_order_id' => $item['send_order_id']], $save_data);
  203. }
  204. }
  205. static function generateStatsByChunk()
  206. {
  207. $fields = DB::raw("send_order_id,max(date) max_date,book_name,bid,sum(uv) sum_uv,sum(pv) sum_pv,sum(recharge_amount) sum_recharge_amount,sum(paid_num) sum_paid_num,sum(unpaid_num) sum_unpaid_num,
  208. distribution_channel_id,max(recharge_amount_in_half_day) max_recharge_amount_in_half_day,max(recharge_amount_in_one_day) max_recharge_amount_in_one_day,max(recharge_amount_in_two_weeks) max_recharge_amount_in_two_weeks,
  209. max(recharge_amount_in_three_days) max_recharge_amount_in_three_days,max(recharge_amount_in_one_day) max_recharge_amount_in_one_day,send_time,cost,sum(year_recharge_user_num) sum_year_recharge_user_num,
  210. sum(ticket_recharge_user_num) sum_ticket_recharge_user_num,sum(first_recharge_amount) sum_first_recharge_amount, sum(first_recharge_user_num) sum_first_recharge_user_num,sum(year_paid_num) sum_year_paid_num,
  211. sum(year_unpaid_num) sum_year_unpaid_num,sum(pay_user_num) sum_pay_user_num,sum(force_user_num) sum_force_user_num,sum(register_user_num) sum_register_user_num,distribution_channel_name,charge_type,name,create_time");
  212. DB::table('send_orders_force_day_stats')
  213. ->select($fields)
  214. ->groupBy('send_order_id')
  215. ->orderBy('send_order_id')
  216. ->chunk(1000, function ($stats) {
  217. foreach ($stats as $stat) {
  218. $end_time = date("Y-m-d", strtotime($stat->max_date) + 86400);
  219. $data = [];
  220. $data['send_order_id'] = $stat->send_order_id;
  221. $data['book_name'] = $stat->book_name;
  222. $data['bid'] = $stat->bid;
  223. $data['uv'] = $stat->sum_uv;
  224. $data['pv'] = $stat->sum_pv;
  225. $data['recharge_amount'] = $stat->sum_recharge_amount;
  226. $data['paid_num'] = $stat->sum_paid_num;
  227. $data['unpaid_num'] = $stat->sum_unpaid_num;
  228. $data['distribution_channel_id'] = $stat->distribution_channel_id;
  229. $data['recharge_amount_in_half_day'] = $stat->max_recharge_amount_in_half_day;
  230. $data['recharge_amount_in_one_day'] = $stat->max_recharge_amount_in_one_day;
  231. $data['recharge_amount_in_two_weeks'] = $stat->max_recharge_amount_in_two_weeks;
  232. $data['recharge_amount_in_three_days'] = $stat->max_recharge_amount_in_three_days;
  233. $data['recharge_amount_in_one_day'] = $stat->max_recharge_amount_in_one_day;
  234. $data['send_time'] = $stat->send_time;
  235. $data['cost'] = $stat->cost;
  236. //付费用户数
  237. $data['year_recharge_user_num'] = (int) DB::table('orders')
  238. ->where('send_order_id', $stat->send_order_id)
  239. ->distinct('uid')->where('order_type', 'YEAR')
  240. ->where('created_at', '<', $end_time)
  241. ->where('status', 'PAID')
  242. ->count();
  243. $data['ticket_recharge_user_num'] = (int) DB::table('orders')->where('send_order_id', $stat->send_order_id)->distinct('uid')->where('order_type', 'RECHARGE')->where('created_at', '<', $end_time)->where('status', 'PAID')->count();
  244. $data['pay_user_num'] = (int) DB::table('orders')->where('send_order_id', $stat->send_order_id)->distinct('uid')->where('status', 'PAID')->where('created_at', '<', $end_time)->count();
  245. $data['first_recharge_amount'] = $stat->sum_first_recharge_amount;
  246. $data['first_recharge_user_num'] = $stat->sum_first_recharge_user_num;
  247. $data['year_paid_num'] = $stat->sum_year_paid_num;
  248. $data['year_unpaid_num'] = $stat->sum_year_unpaid_num;
  249. $data['force_user_num'] = $stat->sum_force_user_num;
  250. $data['register_user_num'] = $stat->sum_register_user_num;
  251. $data['distribution_channel_name'] = $stat->distribution_channel_name;
  252. $data['charge_type'] = $stat->charge_type;
  253. $data['name'] = $stat->name;
  254. $data['create_time'] = $stat->create_time;
  255. SendOrderStat::generateStat($data);
  256. }
  257. });
  258. }
  259. public static function getSendOrdersRechargeDetail($distribution_channels)
  260. {
  261. return SendOrderStat::getBookSendOrdersRechargeStats($distribution_channels);
  262. }
  263. public static function exportSendOrdersRechargeDetail($distribution_channels)
  264. {
  265. return SendOrderStat::exportBookSendOrdersRechargeStats($distribution_channels);
  266. }
  267. static function getChannelPromotionBook($channels, $params, $isAll = false)
  268. {
  269. $orderBy = 'register_user_num';
  270. $obj = SendOrderStat::select(
  271. DB::raw('date(send_orders_stats.send_time) as date'),
  272. 'send_orders_stats.book_name',
  273. 'send_orders_stats.bid',
  274. "channel_users.company_name",
  275. "channel_users.company_id",
  276. DB::raw('sum(register_user_num) as register_user_num'),
  277. DB::raw('sum(uv_one_day) as uv_one_day'),
  278. DB::raw('sum(uv_three_day) as uv_three_day'),
  279. DB::raw('sum(recharge_amount_in_three_days) as recharge_amount_in_three_days'),
  280. DB::raw('sum(recharge_amount_in_one_day) as recharge_amount_in_one_day'),
  281. DB::raw('sum(recharge_amount_in_one_day)/sum(uv_one_day) as percent_recharge_devide_uv'),
  282. DB::raw('sum(recharge_amount_in_three_days)/sum(uv_three_day) as percent_recharge_devide_uv_three_day')
  283. )
  284. ->join("distribution_channels", 'send_orders_stats.distribution_channel_id', "=", "distribution_channels.id")
  285. ->join("channel_users", 'distribution_channels.channel_user_id', "=", "channel_users.id")
  286. ->join('send_order_extra_stats', 'send_orders_stats.send_order_id', '=', 'send_order_extra_stats.send_order_id')
  287. ->groupBy('channel_users.company_id')
  288. ->groupBy('send_orders_stats.book_name')
  289. ->groupBy(DB::raw('date(send_orders_stats.send_time)'));
  290. if ($channels) {
  291. $obj->whereIn('send_orders_stats.distribution_channel_id', $channels);
  292. }
  293. if (isset($params['company_name']) && $params['company_name']) {
  294. $obj->where('channel_users.company_name', $params['company_name']);
  295. }
  296. if (isset($params['book_name']) && $params['book_name']) {
  297. $obj->where('send_orders_stats.book_name', 'like', '%' . $params['book_name'] . '%');
  298. }
  299. if (isset($params['begin_date']) && $params['begin_date']) {
  300. $obj->where(DB::raw('date(send_orders_stats.send_time)'), '>=', $params['begin_date']);
  301. }
  302. if (isset($params['end_date']) && $params['end_date']) {
  303. $obj->where(DB::raw('date(send_orders_stats.send_time)'), '<=', $params['end_date']);
  304. }
  305. if (isset($params['orderBy']) && $params['orderBy']) {
  306. if ($params['orderBy'] == 'register_user_num') {
  307. $orderBy = 'register_user_num';
  308. }
  309. if ($params['orderBy'] == 'percent_recharge_devide_uv') {
  310. $orderBy = 'percent_recharge_devide_uv';
  311. }
  312. if ($params['orderBy'] == 'percent_recharge_devide_uv_three_day') {
  313. $orderBy = 'percent_recharge_devide_uv_three_day';
  314. }
  315. }
  316. $obj->orderBy($orderBy, 'desc');
  317. if ($isAll) {
  318. return $obj->get();
  319. } else {
  320. return $obj->paginate();
  321. }
  322. }
  323. }