WinLoseRankController.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Facade\TableName;
  4. use App\Http\Controllers\Controller;
  5. use App\Http\helper\NumConfig;
  6. use Illuminate\Http\Request;
  7. use Illuminate\Support\Facades\DB;
  8. class WinLoseRankController extends Controller
  9. {
  10. public function index(Request $req)
  11. {
  12. $condition = ['DateID' => date('Ymd')];
  13. $q = DB::table('QPRecordDB.dbo.RecordUserDataStatisticsNew as ruds');
  14. if ($req->input('sort')) {
  15. $sort = $req->input('sort') == 1 ? 'CASE WHEN ruds.TotalBet > 0 THEN (ruds.WinScore - ruds.LostScore)/ruds.TotalBet ELSE 0 END asc' : 'CASE WHEN ruds.TotalBet > 0 THEN (ruds.WinScore - ruds.LostScore)/ruds.TotalBet ELSE 0 END desc';
  16. $q->orderByRaw($sort);
  17. }
  18. $page = $q
  19. ->select([
  20. 'ruds.UserID',
  21. 'ruds.WinScore',
  22. 'ruds.LostScore',
  23. 'ruds.TotalBet',
  24. DB::raw('CASE WHEN ruds.TotalBet > 0 THEN (ruds.WinScore - ruds.LostScore)/ruds.TotalBet ELSE 0 END as rtp'),
  25. DB::raw('0 as sameRW'),
  26. DB::raw('0 as KindID'), DB::raw('0 as TotalRecharge'), DB::raw('0 as TotalWithdraw'),
  27. DB::raw('\'\' as EmailAddress'), DB::raw('\'\' as PhoneNum'), DB::raw('0 as GameID'),
  28. ])->where($condition)
  29. ->paginate(15);
  30. if ($page->count() > 0) {
  31. $uids = array_column($page->items(), 'UserID');
  32. $lockers = DB::table('QPTreasureDB.dbo.GameScoreLocker')->whereIn('UserID', $uids)
  33. ->pluck('KindID', 'UserID')->toArray();
  34. $phones = DB::table('QPAccountsDB.dbo.AccountPhone as ap')->whereIn('UserID', $uids)
  35. ->pluck('PhoneNum', 'UserID')->toArray();
  36. foreach ($page->items() as $key => $item) {
  37. $item->PhoneNum = $phones[$item->UserID] ?? '';
  38. }
  39. $GameIDs = DB::table('QPAccountsDB.dbo.AccountsInfo as ai')->whereIn('UserID', $uids)
  40. ->pluck('GameID', 'UserID')->toArray();
  41. foreach ($page->items() as $key => $item) {
  42. $item->GameID = $GameIDs[$item->UserID] ?? '';
  43. }
  44. $emails = DB::table('QPAccountsDB.dbo.AccountWithdrawInfo as awi')->whereIn('UserID', $uids)
  45. ->pluck('EmailAddress', 'UserID')->toArray();
  46. foreach ($page->items() as $key => $item) {
  47. $item->EmailAddress = $emails[$item->UserID] ?? '';
  48. }
  49. $totals = DB::table('QPRecordDB.dbo.RecordUserTotalStatistics as ruts')->whereIn('UserID', $uids)
  50. ->get()->toArray();
  51. foreach ($page->items() as $key => $item) {
  52. foreach ($totals as $total) {
  53. if ($item->UserID == $total->UserID) {
  54. $item->TotalRecharge = $total->Recharge;
  55. $item->TotalWithdraw = $total->Withdraw;
  56. }
  57. }
  58. }
  59. $phones = array_filter(array_column($page->items(), 'PhoneNum'));
  60. $emails = array_filter(array_column($page->items(), 'EmailAddress'));
  61. $phoneRWs = [];
  62. if (count($phones) > 0) {
  63. $phoneUids = DB::table('QPAccountsDB.dbo.AccountPhone')->whereIn('PhoneNum', $phones)
  64. ->pluck('UserID', 'PhoneNum')->toArray();
  65. if (count($phoneUids) > 0) {
  66. $res = DB::table('QPRecordDB.dbo.RecordUserTotalStatistics')->whereIn('UserID', $phoneUids)
  67. ->get();
  68. foreach ($res as $row) {
  69. $phone = array_search($row->UserID, $phoneUids);
  70. $phoneRWs[$phone] = $row->Recharge - $row->Withdraw/NumConfig::NUM_VALUE;
  71. }
  72. }
  73. }
  74. $emailRWs = [];
  75. if (count($emails) > 0) {
  76. $emailUids = DB::table('QPAccountsDB.dbo.AccountWithdrawInfo')
  77. ->whereIn('EmailAddress', $emails)
  78. ->pluck('UserID', 'EmailAddress')->toArray();
  79. if (count($emailUids) > 0) {
  80. $res = DB::table('QPRecordDB.dbo.RecordUserTotalStatistics')->whereIn('UserID', $emailUids)
  81. ->get();
  82. foreach ($res as $row) {
  83. $email = array_search($row->UserID, $emailUids);
  84. $emailRWs[$email] = $row->Recharge - $row->Withdraw/NumConfig::NUM_VALUE;
  85. }
  86. }
  87. }
  88. foreach ($page as $k => $v) {
  89. $page[$k]->sameRW = ($emailRWs[$v->EmailAddress] ?? 0) + ($phoneRWs[$v->PhoneNum] ?? 0);
  90. $page[$k]->KindID = $lockers[$v->UserID] ?? 0;
  91. }
  92. }
  93. $gameServerNames = DB::table(TableName::QPPlatformDB() . 'RoomConfig')
  94. ->pluck('RoomName', 'GameID')->toArray();
  95. return view('admin.win_lose_rank.index', ['list' => $page, 'gameServerNames' => $gameServerNames, 'request' => $req]);
  96. }
  97. }