12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- <?php
- /**
- * Created by PhpStorm.
- * User: tandunzhao
- * Date: 2018/6/20
- * Time: 下午4:30
- */
- namespace App\Modules\Subscribe\Models;
- use Illuminate\Database\Eloquent\Model;
- use DB;
- class OfficialAccountDaySubStat extends Model
- {
- protected $table = 'official_account_day_sub_stats';
- protected $fillable = [
- 'appid', 'official_account_name', 'date', 'reward_balance', 'charge_balance', 'fee', 'month'
- ];
- public static function getMonthListData($params = [], $isAll = false) {
- $sqlObj = self::select(
- 'appid',
- 'official_account_name',
- 'month',
- DB::raw('sum(reward_balance) as reward_balance'),
- DB::raw('sum(charge_balance) as charge_balance'),
- DB::raw('sum(fee) as fee')
- )->orderBy('date', 'desc');
- if(isset($params['appid']) && $params['appid']) {
- $sqlObj->where('appid', $params['appid']);
- }
- if(isset($params['official_account_name']) && $params['official_account_name']) {
- $sqlObj->where('official_account_name', 'like', "%".$params['official_account_name']."%");
- }
- if(isset($params['start_date']) && $params['start_date']) {
- $sqlObj->where('date', '>=', $params['start_date']);
- }
- if(isset($params['end_date']) && $params['end_date']) {
- $sqlObj->where('date', '<=', $params['end_date']);
- }
- $sqlObj->groupBy('month', 'appid');
- if($isAll) {
- return $sqlObj->get();
- } else {
- return $sqlObj->paginate();
- }
- }
- public static function getDayListData($params = [], $isAll = false) {
- $sqlObj = self::select(
- 'appid',
- 'official_account_name',
- 'date',
- 'month',
- 'reward_balance',
- 'charge_balance',
- 'fee'
- )->orderBy('date', 'desc');
- if(isset($params['appid']) && $params['appid']) {
- $sqlObj->where('appid', $params['appid']);
- }
- if(isset($params['official_account_name']) && $params['official_account_name']) {
- $sqlObj->where('official_account_name', 'like', "%".$params['official_account_name']."%");
- }
- if(isset($params['start_date']) && $params['start_date']) {
- $sqlObj->where('date', '>=', $params['start_date']);
- }
- if(isset($params['end_date']) && $params['end_date']) {
- $sqlObj->where('date', '<=', $params['end_date']);
- }
- $sqlObj->groupBy('date', 'appid');
- if($isAll) {
- return $sqlObj->get();
- } else {
- return $sqlObj->paginate();
- }
- }
- }
|