// +---------------------------------------------------------------------- namespace Admin\Model; use Think\Model; /** * 投放平台模型 * @author 鹿文学 */ class LaunchRecordModel extends Model{ /* 自动验证规则 */ protected $_validate = array( ); /* 自动完成规则 */ protected $_auto = array( ); /** * 构造函数 * @param string $name 模型名称 * @param string $tablePrefix 表前缀 * @param mixed $connection 数据库连接信息 */ public function __construct($name = '', $tablePrefix = '', $connection = '') { /* 设置默认的表前缀 */ $this->tablePrefix ='tab_'; /* 执行构造方法 */ parent::__construct($name, $tablePrefix, $connection); } /** * 投放数据列表 * @param integer $p 页码 * @param array $map 条件数组 * @param integer $start 开始时间 * @param integer $end 结束时间 * @return array 结果数据集 * @author 鹿文学 */ public function lists($p=1,$map=array(),$start='',$end='') { $page = intval($p); $page = $page ? $page : 1; //默认显示第一页数据 if(isset($_REQUEST['row'])) {$row = $_REQUEST['row'];}else{$row = 10;} $currentdate = mktime(0,0,0,date('m'),date('d'),date('Y')); $launch_data = D('LaunchData'); if(empty($start)) { $time = ['duration'=>['lt',$currentdate]]; $data = $launch_data->data($p,$row,$map,$time,1); } elseif(date('Ymd',$start) != date('Ymd',$end)) { $time = ['duration'=>['between',[$start,$currentdate-1]]]; $data = $launch_data->data($p,$row,$map,$time,1); } else { $data = ['data'=>[],'count'=>1]; } if(empty($map)) {$time['mark']=1;}else{$time['mark']=0;$time = array_merge($time,$map);} /* 计算今天的实时数据 */ $today = $this->data_day($map,$currentdate,$end); $today = $launch_data->data_assembly($today); $total = $launch_data->data_total($time,$today); if($p==1) { array_unshift($data['data'],$today); } $current = $launch_data->accumulation([],$data['data']); $data['current'] = $launch_data->data_assembly($current); $data['total'] = $total; $page = set_pagination($data['count'],$row); if($page) {$data['page']=$page;} return $data; } /** * 计算一天的实时数据 * @param array $map 条件数组 * @param integer $start 开始时间(时间戳) * @param integer $end 结束时间(时间戳) * @return array 结果集 * @author 鹿文学 */ public function data_day($map,$start,$end) { $data = []; $extend = $map; $extend['create_time'] = array('between',[$start,$end]); $new = $this->where($extend)->select(); $register = $this->field('user_id')->where($map)->select(); $device = $this->where(array_merge($extend,['unique_code'=>array('neq','')]))->group('unique_code')->count(); unset($map['platform_id']); $userlogin = D('UserLoginRecord'); $spend = D('Spend'); $userloginmap = $spendmap = $map; $newids = array_column($new,'user_id'); $spendmap['pay_time']=array('between',[$start,$end]); $new_pay = 0; $new_money = 0; if(!empty($newids)) { $spendmap['user_id'] = array('in',$newids); $new_pay = $spend->player($spendmap); $new_money = $spend->amount($spendmap); } $regids = array_column($register,'user_id'); $userloginmap['login_time'] = array('between',[$start,$end]); $iserloginmap['user_id'] = array('in',$regids); $active = $userlogin->active($userloginmap); $activeids = array_column($active,'user_id'); $active_pay = 0; $active_money = 0; if(!empty($activeids)) { $spendmap['user_id'] = array('in',$activeids); $active_pay = $spend->player($spendmap); $active_money = $spend->amount($spendmap); } $data['new'] = count($new); $data['duration'] = strtotime(date('Y-m-d')); $data['new_device'] = $device; $data['new_pay'] = $new_pay; $data['new_money'] = $new_money; $data['active'] = count($active); $data['active_pay'] = $active_pay; $data['active_money'] = $active_money; $data['game_id'] = $extend['game_id']?$extend['game_id']:0; $data['platform_id'] = $extend['platform_id']?$extend['platform_id']:0; return $data; } /** * 投放数据列表(截止到昨天) * @param integer $p 页码 * @param array $map 条件数组 * @param array $time 时间数组 * @return array 结果数据集 * @author 鹿文学 */ public function data($p=1,$map=array(),$time=array()) { return D('LaunchData')->lists($p,$map,$time); } /** * 获取最早的数据时间 * @author 鹿文学 */ public function get_old_line_time() { $result = $this->field('create_time')->order('create_time asc')->find(); return $result['create_time']?$result['create_time']:0; } /** * 查找数据列表(从之前某天到昨天的数据的统计) * @param integer $start 开始时间 * @param integer $end 结束时间 * @author 鹿文学 */ public function auto_data($start,$end) { if(empty($start) || empty($end)) {return '';} $datelist = get_date_list($start,$end); $userlogin = D('UserLoginRecord'); $spend = D('Spend'); $launch_data = D('LaunchData'); $data = []; foreach($datelist as $k => $v) { $time = strtotime($v); $result = $this->get_data_day($time,$time+86399,$userlogin,$spend,$launch_data); if(!empty($result)) { $data = array_merge($data,$result); } } return $data; } /** * 查找每天数据 * @param integer $start 开始时间 * @param integer $end 结束时间 * @author 鹿文学 */ public function get_data_day($start,$end,$userlogin,$spend,$launch_data) { $newmap['create_time'] = array('between',[$start,$end]); /* 新玩家 */ $new = $this->field('platform_id,promote_id,game_id,group_concat(id) as ids,group_concat(user_id) as newids,count(user_id) as new') ->where($newmap)->group('platform_id,promote_id,game_id')->select(); $newmap['unique_code'] = array('neq',''); $spendmap2['pay_time'] = $spendmap['pay_time']=array('between',[$start,$end]); /* 活跃玩家 */ $active = $userlogin->active_by_launch_record($start,$end,$this); $total = ['platform_id'=>0,'platform_name'=>'','promote_id'=>0,'promote_account'=>'','game_id'=>0,'game_name'=>'','new'=>0,'new_device'=>0,'new_pay'=>0,'new_money'=>0,'active'=>0,'active_pay'=>0,'active_money'=>0,'duration'=>$start+28800,'mark'=>1,'create_time'=>time()]; foreach($active as $k => $v) { $temp = array( 'platform_id'=>$v['platform_id'], 'platform_name'=>$v['platform_name'], 'promote_id'=>$v['promote_id'], 'promote_account'=>$v['promote_account'], 'game_id'=>$v['game_id'], 'game_name'=>$v['game_name'], 'active'=>$v['active'], 'mark'=>0,'new'=>0,'new_device'=>0,'new_pay'=>0,'new_money'=>0,'create_time'=>time(), ); $spendmap2['user_id'] = array('in',$v['activeids']); $temp['active_pay'] = $spend->player($spendmap2); $temp['active_money'] = $spend->amount($spendmap2); $temp['duration'] = $start+28800; foreach($new as $key => $value) { if($value['platform_id']==$v['platform_id'] && $value['promote_id']==$v['promote_id'] && $value['game_id']==$v['game_id']) { $temp['new'] = $value['new']; $spendmap['user_id'] = array('in',$value['newids']); $newmap['id'] = array('in',$value['ids']); $device = $this->field('id')->where($newmap)->group('unique_code')->select(); $temp['new_device'] = count($device); $temp['new_pay'] = $spend->player($spendmap); $temp['new_money'] = $spend->amount($spendmap); } } $temp = $launch_data->data_assembly($temp); $total['new'] += $temp['new']; $total['new_device'] += $temp['new_device']; $total['new_pay'] += $temp['new_pay']; $total['new_money'] += $temp['new_money']; $total['active'] += $temp['active']; $total['active_pay'] += $temp['active_pay']; $total['active_money'] += $temp['active_money']; ksort($temp); $data[$k]=$temp; } $total = $launch_data->data_assembly($total); ksort($total); array_unshift($data,$total); return $data; } /** * 根据时间分组获取新玩家 * @param array $map 条件数组 * @param string $field 字段别名 * @param string $group 分组字段名 * @author 鹿文学 */ public function news($map=array(),$field='news',$group='time',$flag=1,$order='time') { switch($flag) { case 2:{$dateform = '%Y-%m';};break; case 3:{$dateform = '%Y-%u';};break; case 4:{$dateform = '%Y';};break; case 5:{$dateform = '%Y-%m-%d %H';};break; default:$dateform = '%Y-%m-%d'; } $user = $this->field('FROM_UNIXTIME(create_time, "'.$dateform.'") as '.$group.',group_concat(user_id) as id ,COUNT(user_id) AS '.$field) ->where($map) ->group($group) ->order($order) ->select(); return $user; } /** * 根据时间分组获取新设备 * @param array $map 条件数组 * @param string $field 字段别名 * @param string $group 分组字段名 * @author 鹿文学 */ public function device($map=array(),$field='news',$group='time',$flag=1,$order='time') { switch($flag) { case 2:{$dateform = '%Y-%m';};break; case 3:{$dateform = '%Y-%u';};break; case 4:{$dateform = '%Y';};break; case 5:{$dateform = '%Y-%m-%d %H';};break; default:$dateform = '%Y-%m-%d'; } $map['unique_code'] = array('neq',''); $user = $this->field('FROM_UNIXTIME(create_time, "'.$dateform.'") as '.$group.',group_concat(unique_code) as id ,COUNT(unique_code) AS '.$field) ->where($map) ->group($group) ->order($order) ->select(); return $user; } /** * 创建时间不写则取当前时间 * @return int 时间戳 * @author huajie */ protected function getCreateTime(){ $create_time = I('post.create_time'); return $create_time?strtotime($create_time):NOW_TIME; } protected function getUpdateTime(){ $update_time = I('post.update_time'); return $update_time?strtotime($update_time):NOW_TIME; } /** * 新增或更新一个游戏 * @param array $data 手动传入的数据 * @return boolean fasle 失败 , int 成功 返回完整的数据 * @author 王贺 */ public function update($data = null){ /* 获取数据对象 */ $data = $this->token(false)->create($data); if(empty($data)){ return false; } /* 添加或新增基础内容 */ if(empty($data['id'])){ //新增数据 $id = $this->add($data); //添加基础内容 if(!$id){ $this->error = '新增基础内容出错!'; return false; } } else { //更新数据 $status = $this->save(); //更新基础内容 if(false === $status){ $this->error = '更新基础内容出错!'; return false; } } return $data; } }