Mysql
접속자 통계
NaHyungMin
2018. 9. 13. 17:48
dau, mau, 주간 통계까지 넣어 본 통계
이벤트 스케쥴러로 원하는 시간 대에 돌리면 된다.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 | CREATE DEFINER=`definer`@`%` PROCEDURE `sys_statistics_active_user`() BEGIN declare $daily_user_count int; declare $week_end_date date; declare $week_user_count int; declare $month_last_date date; declare $month_user_count int; DECLARE EXIT HANDLER FOR SQLEXCEPTION BEGIN -- default exception handler ROLLBACK; SET @@SQL_SAFE_UPDATES=1; RESIGNAL; END; #daily set $daily_user_count = (select count(*) from `user_public_data` where date(`login_time`) = CURRENT_DATE); insert into `statistics_daily_active_user`(`statistics_date`, `user_count`) values (CURRENT_DATE, $daily_user_count); #week set $week_end_date = DATE_FORMAT(DATE_SUB(current_date, INTERVAL (DAYOFWEEK(current_date)-7) DAY), '%Y-%m-%d'); #week 마지막 날 갱신 if($week_end_date = CURRENT_DATE) then begin set $week_user_count = (select * from `user_public_data` where date(`login_time`) >= DATE_FORMAT(DATE_SUB(current_date, INTERVAL (DAYOFWEEK(current_date)-1) DAY), '%Y-%m-%d') and date(`login_time`) <= DATE_FORMAT(DATE_SUB(current_date, INTERVAL (DAYOFWEEK(current_date)-7) DAY), '%Y-%m-%d')); insert into `statistics_week_active_user`(`statistics_start_week_date`, `statistics_end_week_date`, `user_count`) values (DATE_FORMAT(DATE_SUB(current_date, INTERVAL (DAYOFWEEK(current_date)-1) DAY), '%Y-%m-%d'), $week_end_date, $week_user_count); end; end if; #month set $month_last_date = last_day(CURRENT_DATE); if($month_last_date = CURRENT_DATE) then begin set $month_user_count = (select count(*) from `user_public_data` where DATE_FORMAT(`login_time`, '%Y-%m') = DATE_FORMAT(current_date, '%Y-%m')); insert into `statistics_month_active_user` (`statistics_month`, `user_count`) values (DATE_FORMAT(current_date, '%Y-%m'), $month_user_count); end; end if; END | cs |
추가 이벤트 스케줄러
1 2 3 4 5 6 7 8 | show events; CREATE DEFINER = `definer` EVENT statistics_active_user ON SCHEDULE EVERY 24 HOUR STARTS CURRENT_TIMESTAMP + INTERVAL 13 HOUR COMMENT '통계용' DO call sys_statistics_active_user(); | cs |
23시50~59분 사이에서 시작하려고 현재 시간 + 13시간 뒤부터 시작하도록 설정
하루에 한번 돌도록 구현