Ranking.php 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. <?php
  2. namespace App\Repositories\Models\Dwbs;
  3. use App\Repositories\Enums\Dwbs\DayTypeEnum;
  4. use App\Repositories\Enums\ModelStatusEnum;
  5. use App\Repositories\Models\Base\User;
  6. use App\Repositories\Models\Model;
  7. use Carbon\Carbon;
  8. use Illuminate\Support\Facades\Cache;
  9. class Ranking extends Model
  10. {
  11. /**
  12. * @var string
  13. */
  14. protected $table = 'dwbs_user_statistical';
  15. protected $guarded = [];
  16. /**
  17. * The attributes excluded from the model's JSON form.
  18. *
  19. * @var array
  20. */
  21. protected $hidden = [];
  22. protected $casts = [];
  23. public function user()
  24. {
  25. return $this->belongsTo(User::class)->select(['id', 'nickname', 'headimg', 'nickname', 'mobile_code', 'mobile', 'mobile_encryption','group_id']);
  26. }
  27. public static function byDayGetUserXuefen($day, $user_id)
  28. {
  29. if ($day == date('Y-m-d')) {
  30. $xuefen = UserXuefen::query()->where('day', $day)->where('user_id', $user_id)->where('status', ModelStatusEnum::OK)->sum('xuefen');
  31. return [
  32. 'day_xuefen' => $xuefen,
  33. 'xuefen' => User::query()->where('id', $user_id)->value('xuefen'),
  34. ];
  35. }
  36. return Cache::remember("model:ranking:byDayGetUserGoodNums:{$day}:{$user_id}", Carbon::now()->addDay(), function () use ($day, $user_id) {
  37. $model = self::query()->where('day', $day)->where('day_type', DayTypeEnum::day)->where('user_id', $user_id)->where('status', ModelStatusEnum::OK)->select(['day_xuefen', 'xuefen'])->first();
  38. if ($model) return $model->toArray();
  39. return [
  40. 'day_xuefen' => 0,
  41. 'xuefen' => 0,
  42. ];
  43. });
  44. }
  45. }