OfficialAccountDaySubStat.php 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: tandunzhao
  5. * Date: 2018/6/20
  6. * Time: 下午4:30
  7. */
  8. namespace App\Modules\Subscribe\Models;
  9. use Illuminate\Database\Eloquent\Model;
  10. use DB;
  11. class OfficialAccountDaySubStat extends Model
  12. {
  13. protected $table = 'official_account_day_sub_stats';
  14. protected $fillable = [
  15. 'appid', 'official_account_name', 'date', 'reward_balance', 'charge_balance', 'fee', 'month'
  16. ];
  17. public static function getMonthListData($params = [], $isAll = false) {
  18. $sqlObj = self::select(
  19. 'appid',
  20. 'official_account_name',
  21. 'month',
  22. DB::raw('sum(reward_balance) as reward_balance'),
  23. DB::raw('sum(charge_balance) as charge_balance'),
  24. DB::raw('sum(fee) as fee')
  25. )->orderBy('date', 'desc');
  26. if(isset($params['appid']) && $params['appid']) {
  27. $sqlObj->where('appid', $params['appid']);
  28. }
  29. if(isset($params['official_account_name']) && $params['official_account_name']) {
  30. $sqlObj->where('official_account_name', 'like', "%".$params['official_account_name']."%");
  31. }
  32. if(isset($params['start_date']) && $params['start_date']) {
  33. $sqlObj->where('date', '>=', $params['start_date']);
  34. }
  35. if(isset($params['end_date']) && $params['end_date']) {
  36. $sqlObj->where('date', '<=', $params['end_date']);
  37. }
  38. $sqlObj->groupBy('month', 'appid');
  39. if($isAll) {
  40. return $sqlObj->get();
  41. } else {
  42. return $sqlObj->paginate();
  43. }
  44. }
  45. public static function getDayListData($params = [], $isAll = false) {
  46. $sqlObj = self::select(
  47. 'appid',
  48. 'official_account_name',
  49. 'date',
  50. 'month',
  51. 'reward_balance',
  52. 'charge_balance',
  53. 'fee'
  54. )->orderBy('date', 'desc');
  55. if(isset($params['appid']) && $params['appid']) {
  56. $sqlObj->where('appid', $params['appid']);
  57. }
  58. if(isset($params['official_account_name']) && $params['official_account_name']) {
  59. $sqlObj->where('official_account_name', 'like', "%".$params['official_account_name']."%");
  60. }
  61. if(isset($params['start_date']) && $params['start_date']) {
  62. $sqlObj->where('date', '>=', $params['start_date']);
  63. }
  64. if(isset($params['end_date']) && $params['end_date']) {
  65. $sqlObj->where('date', '<=', $params['end_date']);
  66. }
  67. $sqlObj->groupBy('date', 'appid');
  68. if($isAll) {
  69. return $sqlObj->get();
  70. } else {
  71. return $sqlObj->paginate();
  72. }
  73. }
  74. }