where('jointime', 'between time', [$starttime, $endtime]) ->field('jointime, status, COUNT(*) AS nums, DATE_FORMAT(FROM_UNIXTIME(jointime), "%Y-%m-%d") AS join_date') ->group('join_date') ->select(); for ($time = $starttime; $time <= $endtime;) { $column[] = date("Y-m-d", $time); $time += 86400; } $userlist = array_fill_keys($column, 0); foreach ($joinlist as $k => $v) { $userlist[$v['join_date']] = $v['nums']; } $this->view->assign([ 'totaluser' => User::count(), 'totalorder' => Db::name('unishop_order')->where('status',1)->where('have_paid','gt',0)->count(), 'kongjianyuyue' => Db::name('kongjianyuyue')->count(), 'laorenguanhuai' => Db::name('laorenguanhuai')->count(), 'service_grade' => Db::name('service_grade')->count(), 'topic_dongtai' => Db::name('topic_dongtai')->where('auditstatus',1)->count(), 'exam_grade' => Db::name('exam_grade')->where('status',2)->count(), 'todayusersignup' => User::whereTime('jointime', 'today')->count(), 'todayuserlogin' => User::whereTime('logintime', 'today')->count(), 'sevendau' => User::whereTime('jointime|logintime|prevtime', '-7 days')->count(), 'thirtydau' => User::whereTime('jointime|logintime|prevtime', '-30 days')->count(), 'threednu' => User::whereTime('jointime', '-3 days')->count(), 'sevendnu' => User::whereTime('jointime', '-7 days')->count(), ]); $this->assignconfig('column', array_keys($userlist)); $this->assignconfig('userdata', array_values($userlist)); return $this->view->fetch(); } }