From 34e25f293a18507f1c4a53cac01de1e1253a3451 Mon Sep 17 00:00:00 2001 From: "elf@home" <360197197@qq.com> Date: Thu, 21 Jan 2021 22:48:49 +0800 Subject: [PATCH 1/2] =?UTF-8?q?=E6=8E=A8=E5=B9=BF=E5=91=98=E6=B7=BB?= =?UTF-8?q?=E5=8A=A0=E6=AF=8F=E7=BA=A7id?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Application/Base/Service/PromoteService.class.php | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/Application/Base/Service/PromoteService.class.php b/Application/Base/Service/PromoteService.class.php index 23828a922..383da0f30 100644 --- a/Application/Base/Service/PromoteService.class.php +++ b/Application/Base/Service/PromoteService.class.php @@ -205,11 +205,13 @@ class PromoteService { M('promote', 'tab_')->where($firstMap)->save([ 'parent_id' => $toPromote['id'], 'parent_name' => $toPromote['account'], - 'chain' => $toPromote['chain'] . $toPromote['id'] . '/' + 'chain' => $toPromote['chain'] . $toPromote['id'] . '/', + 'level' . $toPromote['level'] => $toPromote['id'] ]); M('promote', 'tab_')->where($secondMap)->save([ 'chain' => ['exp', 'REPLACE(chain, "/' . $fromPromote['id'] . '/","/' . $toPromote['id'] . '/")'], + 'level' . $toPromote['level'] => $toPromote['id'] ]); $status = M('ShiftTask')->where('id=' . $task['id'])->save(['status' => 1, 'handle_time' => time()]); @@ -1069,6 +1071,16 @@ class PromoteService { resetUserAuth(); } + $fullChain = $data['chain'] . $insert; + $fullChainList = explode('/', trim($fullChain, '/')); + + M('promote', 'tab_')->where(['id' => $insert])->update([ + 'level1_id' => $fullChainList[0] ?? 0, + 'level2_id' => $fullChainList[1] ?? 0, + 'level3_id' => $fullChainList[2] ?? 0, + 'level4_id' => $fullChainList[3] ?? 0, + ]); + return $insert; } From 531b94bae88786f5b9f0d95ddf18d83f2530e71c Mon Sep 17 00:00:00 2001 From: ELF <360197197@qq.com> Date: Tue, 26 Jan 2021 15:19:19 +0800 Subject: [PATCH 2/2] =?UTF-8?q?=E7=89=88=E6=9C=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../Controller/ConsoleController.class.php | 82 +++++++++++++++++++ .../Base/Service/PromoteService.class.php | 32 +++++--- Application/Base/Tool/Redis.class.php | 16 ++++ .../Home/Controller/QueryController.class.php | 4 +- Data/update.sql | 12 +++ 5 files changed, 132 insertions(+), 14 deletions(-) diff --git a/Application/Admin/Controller/ConsoleController.class.php b/Application/Admin/Controller/ConsoleController.class.php index 3c10092fa..c36acb21f 100644 --- a/Application/Admin/Controller/ConsoleController.class.php +++ b/Application/Admin/Controller/ConsoleController.class.php @@ -14,6 +14,8 @@ use Base\Task\Task; use Base\Service\MarketService; use Base\Tool\AggregateClient; use Base\Repository\GameRepository; +use Base\Tool\Redis; +use Think\Model; class ConsoleController extends Think { @@ -666,4 +668,84 @@ class ConsoleController extends Think { } echo '' . PHP_EOL . $trs . '
'; } + + public function generateHistoryGame() + { + $items = M('spend', 'tab_') + ->field(['tab_promote.level1_id', 'group_concat(distinct tab_spend.game_id) game_ids']) + ->join('left join tab_promote on tab_spend.promote_id=tab_promote.id') + ->where('tab_spend.is_check=1 and tab_spend.pay_status=1') + ->group('tab_promote.level1_id') + ->select(); + foreach ($items as $item) { + if ($item['level1_id']) { + $key = Redis::getKey('promote_history_games', ['promote_id' => $item['level1_id']]); + Redis::set($key, $item['game_ids']); + } + } + } + + public function updateHistoryGame() + { + $items = M('spend', 'tab_') + ->field(['tab_promote.level1_id', 'group_concat(distinct tab_spend.game_id) game_ids']) + ->join('left join tab_promote on tab_spend.promote_id=tab_promote.id') + ->where('tab_spend.is_check=1 and tab_spend.pay_status=1 and tab_spend.pay_time>' . strtotime(date('Y-m-d 00:00:00'))) + ->group('tab_promote.level1_id') + ->select(); + foreach ($items as $item) { + if ($item['level1_id']) { + $key = Redis::getKey('promote_history_games', ['promote_id' => $item['level1_id']]); + $value = Redis::get($key); + $gameIds = $value ? explode(',', $value) : []; + $nowGameIds = explode(',', $item['game_ids']); + $gameIds = array_unique(array_merge($gameIds, $nowGameIds)); + Redis::set($key, implode(',', $gameIds)); + } + } + } + + public function generatePromotesLevelId() + { + $promotes = M('promote', 'tab_')->field(['chain', 'id'])->select(); + foreach ($promotes as $promote) { + $fullChain = explode('/', $promote['chain'] . $promote['id']); + M('promote', 'tab_')->where(['id' => $promote['id']])->save([ + 'level1_id' => $fullChain[1] ?? 0, + 'level2_id' => $fullChain[2] ?? 0, + 'level3_id' => $fullChain[3] ?? 0, + 'level4_id' => $fullChain[4] ?? 0, + ]); + } + } + + public function setUserFirstPayTime() + { + $hasNext = true; + $limit = 500; + $lastId = 0; + do { + $items = M('spend', 'tab_') + ->field(['user_id', 'min(pay_time) first_pay_time']) + ->where(['pay_status' => 1, 'user_id' => ['gt', $lastId]]) + ->group('user_id') + ->order('user_id asc') + ->limit($limit) + ->select(); + + $model = new Model(); + $model->startTrans(); + foreach ($items as $item) { + M('user', 'tab_')->where(['id' => $item['user_id']])->save([ + 'first_pay_time' => $item['first_pay_time'] + ]); + $lastId = $item['user_id']; + } + $model->commit(); + + if (count($items) < $limit) { + $hasNext = false; + } + } while($hasNext); + } } diff --git a/Application/Base/Service/PromoteService.class.php b/Application/Base/Service/PromoteService.class.php index 383da0f30..6ab11124b 100644 --- a/Application/Base/Service/PromoteService.class.php +++ b/Application/Base/Service/PromoteService.class.php @@ -7,6 +7,7 @@ use Base\Model\UserPlayModel; use Base\Model\UserModel; use Base\Tool\IdCard; use Base\Tool\Registry; +use Base\Tool\Redis; use Think\Model; use Base\Repository\SpendRepository; @@ -396,6 +397,11 @@ class PromoteService { } } + $toTopPromote = $this->getTopPromote($toPromote); + $hasGameIds = $toTopPromote['game_ids'] == '' ? [] : explode(',', $toTopPromote['game_ids']); + $hasNotGameIds = M('game', 'tab_')->where(['game_id' => ['not in', $hasGameIds]])->getField('id', true); + $hasNotGameIds = $hasNotGameIds ?? []; + $model = new Model(); $model->startTrans(); @@ -433,7 +439,17 @@ class PromoteService { M('user_play_info', 'tab_')->where($otherMap)->save($updateData); unset($spendMap['pay_status']); - M('spend', 'tab_')->where($spendMap)->save(array_merge($updateData, $updateMarket)); // 只改未对账的数据 + + $updateCheck = []; + if (count($hasGameIds) > 0) { + $spendMap['game_id'] = ['in', $hasGameIds]; + M('spend', 'tab_')->where($spendMap)->save(array_merge($updateData, $updateMarket, ['is_check' => 1])); + } + + if (count($hasNotGameIds) > 0) { + $spendMap['game_id'] = ['in', $hasNotGameIds]; + M('spend', 'tab_')->where($spendMap)->save(array_merge($updateData, $updateMarket, ['is_check' => 0])); + } $bindMap = $otherMap; $bindMap['pay_time'] = ['egt', $orderTime]; @@ -1253,17 +1269,9 @@ class PromoteService { public function getHistoryGameIds($promote) { $topPromote = $this->getTopPromote($promote); - - $spendRepository = new SpendRepository(); - - $map = []; - $map['_string'] = ' promote_id in(' . $this->subInSql($topPromote) . ')'; - $map = $spendRepository->withIsCheck($map); - $historyGames = M('spend', 'tab_')->field(['distinct game_id'])->where($map)->select(); - $historyGameIds = []; - if ($historyGames) { - $historyGameIds = array_column($historyGames, 'game_id'); - } + $key = Redis::getKey('promote_history_games', ['promote_id' => $item['level1_id']]); + $value = Redis::get($key); + $historyGameIds = $value ? explode(',', $value) : []; $nowGameIds = $topPromote['game_ids'] == '' ? [] : explode(',', $topPromote['game_ids']); return array_unique(array_merge($historyGameIds, $nowGameIds)); } diff --git a/Application/Base/Tool/Redis.class.php b/Application/Base/Tool/Redis.class.php index 8c8988b1a..329880bb8 100644 --- a/Application/Base/Tool/Redis.class.php +++ b/Application/Base/Tool/Redis.class.php @@ -8,6 +8,22 @@ class Redis { private static $handler; + public static $allKeys = [ + 'promote_history_games' => 'promote_history_games:{promote_id}', // 会长历史游戏 + ]; + + public static function getKey($name, $params = []) + { + $realKey = self::$allKeys[$name] ?? null; + if (is_null($realKey)) { + throw new \Exception('KEY不存在'); + } + foreach ($params as $key => $value) { + $realKey = str_replace('{' . $key . '}', $value, $realKey); + } + return $realKey; + } + public static function getHandler() { if(self::$handler == null) { diff --git a/Application/Home/Controller/QueryController.class.php b/Application/Home/Controller/QueryController.class.php index c73569d46..16300c0c8 100644 --- a/Application/Home/Controller/QueryController.class.php +++ b/Application/Home/Controller/QueryController.class.php @@ -801,7 +801,7 @@ class QueryController extends BaseController $newPayUserCountList = $spendRepository->getNewPayUserCountGroupByDay($params); $payAmountList = $spendRepository->getPayAmountGroupByDay($params); $newPayAmountList = $spendRepository->getNewPayAmountGroupByDay($params); - $historyPayCountList = $spendRepository->getHistoryPayCountGroupByDay($params); + // $historyPayCountList = $spendRepository->getHistoryPayCountGroupByDay($params); $loginCountList = $userRepository->getLoginCountGroupByDay($params); $registerCountList = $userRepository->getRegisterCountGroupByDay($params); @@ -813,7 +813,7 @@ class QueryController extends BaseController 'newPayUserCount' => $newPayUserCountList[$day], 'payAmount' => number_format($payAmountList[$day], 2), 'newPayAmount' => number_format($newPayAmountList[$day], 2), - 'historyPayCount' => $historyPayCountList[$day], + // 'historyPayCount' => $historyPayCountList[$day], 'loginCount' => $loginCountList[$day], 'registerCount' => $registerCountList[$day], 'payRate' => $loginCountList[$day] == 0 ? '--' : round($payUserCountList[$day] / $loginCountList[$day] * 100, 2) . '%', diff --git a/Data/update.sql b/Data/update.sql index 308fb3613..d48d00763 100644 --- a/Data/update.sql +++ b/Data/update.sql @@ -2781,3 +2781,15 @@ ALTER TABLE `tab_testing_resource_batch` ADD COLUMN `verify_admin_id` int(11) NOT NULL DEFAULT 0 COMMENT '審核管理員ID' AFTER `verify_status`; ALTER TABLE `tab_testing_resource_batch` ADD COLUMN `apply_admin_id` int(11) NOT NULL DEFAULT 0 COMMENT '申請管理員ID' AFTER `apply_promote_id`; + +ALTER TABLE `tab_promote` +ADD COLUMN `level1_id` int(11) NOT NULL DEFAULT 0 COMMENT '一级推广员ID(会长)' AFTER `chain`; +ALTER TABLE `tab_promote` +ADD COLUMN `level2_id` int(11) NOT NULL DEFAULT 0 COMMENT '二级推广员ID(部门长)' AFTER `level1_id`; +ALTER TABLE `tab_promote` +ADD COLUMN `level3_id` int(11) NOT NULL DEFAULT 0 COMMENT '三级推广员ID(组长)' AFTER `level2_id`; +ALTER TABLE `tab_promote` +ADD COLUMN `level4_id` int(11) NOT NULL DEFAULT 0 COMMENT '四级推广员ID(推广员)' AFTER `level3_id`; + +ALTER TABLE `tab_user` +ADD COLUMN `first_pay_time` int(11) NOT NULL DEFAULT 0 COMMENT '首次充值时间' AFTER `fgame_name`; \ No newline at end of file