MySQL 서브쿼리 - 바로 이전 값과 비교해서 올라갔는지, 내려갔는지 확인하는 쿼리
2019.02.21 17:34
서브쿼리 - 바로 이전 값과 비교해서 얼마나 올라갔는지, 얼마나 내려갔는지 확인할 수 있는 쿼리
game_ccu_log 라는 테이블에 "YYYY-MM-DD HH:MM:SS" 로 ccu_count 라는 값이 저장되어 있다면,
아래와 같은 서브쿼리를 이용해서 바로 이전과 비교해서 ccu_count 값이 올라갔는지, 내려갔는지.
올라갔다면 이전 값에 비해 몇 퍼센트 올라갔는지 알 수 있습니다.
Select reg_time, ccu_count, diff_time, diff_count, ccu_count*0.07 as ccu_7p, if(diff_count<0,diff_count*-1, diff_count) as diff_count2, if(ccu_count*0.07 < if(diff_count<0,diff_count*-1, diff_count),1,0) as check_ccu, adddate(reg_time,interval 9 hour) as reg_time2 FROM ( Select reg_time, ccu_count, timediff(now(), t1.reg_time)>'00:05:00' as diff_time, ( cast(t1.ccu_count as signed)- ( SELECT cast(t2.ccu_count as signed) FROM game_ccu_log as t2 WHERE server_type='Game' and t2.reg_time < t1.reg_time ORDER BY t2.reg_time DESC LIMIT 1 ) ) as diff_count FROM game_ccu_log as t1 WHERE reg_time>='${date_now}' AND server_type='GameCCU' ORDER BY reg_time desc limit 1 ) as a
날짜 데이터는 ${date_now} <- 이런 식으로 변수로 입력받게 되어있습니다.
적절하게 사용하면 동접 급감, 급증에 대한 알람을 받을 수 있습니다.
댓글 0
번호 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|
10 | Linux, nginx, MySQL, PHP-FPM 최적화 [7] | MaraSong | 2019.04.18 | 3308 |
9 | 크론탭 crontab 정리 | MaraSong | 2019.03.14 | 1897 |
8 | Installing Nagios Agent (NRPE) on CentOS 7 | MaraSong | 2019.04.17 | 1209 |
7 | apache + letsencrypt (무료 SSL 인증기관 인증서) 설치 및 설정 | MaraSong | 2019.01.31 | 1086 |
6 | iptables - 커넥션 갯수로 특정 아이피 차단하기 | MaraSong | 2019.02.12 | 1083 |
5 | CentOS + Nagios 센트OS 에서 나기오스 설치하기 | MaraSong | 2019.01.31 | 1055 |
4 | bash - 소수점 둘째자리에서 반올림 | MaraSong | 2019.06.11 | 1043 |
3 | 리눅스 서버 모니터링 - 모니터릭스 https://www.monitorix.org/ | MaraSong | 2019.03.12 | 994 |
2 | AWS - 아마존 리눅스 linux 설치후 기본적으로 해야할 일 | MaraSong | 2019.02.27 | 976 |
1 | Bash - 자주 쓰는 함수 | MaraSong | 2019.02.01 | 796 |
* 쿠팡 파트너스 활동을 통해 일정액의 수수료를 제공받을 수 있습니다.