[이윰] 출석부 랭킹 중복 방지하기

페이지 정보

shadow2fox 2,928 5 4 2019.12.16 17:33

평점

본문

출석부 랭킹 중복 방지하기
이윰빌더에서 판매하는 출석부는 그누보드에 정의된 시간상수를 통해 출석시간을 초단위로 DB에 저장하는데 회원들이 동시다발적으로 출석을 하게 되면 중복순위가 나오기 마련이고 그로인해 랭킹 순위와 선착순 순위가 의도치 않는 결과를 야기함으로 출석시간이 밀리세컨드(milliseconds, 천분의 1초) 혹은 마이크로세컨드(microseconds, 백만분의 1초)로 저장되도록 수정해 보자.

아래 예제는 마이크로세컨드(microseconds) 사용시

1. 그누보드5/eyoom/user_program/page/attendance.php를 열어 // 내용글은 텍스트 필터를 검색한다.


수정 전

                $set = "
수정 후

                //밀리세컨드, 마이크로세컨드
                $t_true = microtime(true);
                //$milli = sprintf("%03d",($t_true - floor($t_true)) * 1000);
                $micro = sprintf("%06d",($t_true - floor($t_true)) * 1000000);

                $set = "

atd_datetime = '".G5_TIME_YMDHIS."'를 검색하여 다음과 같이 수정한다.

수정 전

atd_datetime = '".G5_TIME_YMDHIS."'
수정 후

atd_datetime = '".date('Y-m-d H:i:s.'.$micro)."'

atd_datetime` datetime NOT NULL default '0000-00-00 00:00:00',를 검색하여 다음과 같이 수정한다.

수정 전

`atd_datetime` datetime NOT NULL default '0000-00-00 00:00:00',
수정 후

`atd_datetime` datetime(6) NOT NULL default '0000-00-00 00:00:00.000000',

2. 이윰빌더 출석부 attendance.php에 정의된 출석시간(atd_datetime)에 대한 기본 테이블 형식과 기본값을 마이크로세컨드가 적용될 수 있도록 DB관리용 프로그램(phpmyadmin, adminer)이나 커맨드, 터미널 명령어를 통해 g5_eyoom_attendance 테이블의 atd_datetime 컬럼 중 datetime 타입 길이와 기본값을 변경한다.

► 마이크로세컨드 이용시
datetime 길이를 6으로 변경
기본값을 0000-00-00 00:00:00.000000
► 밀리세컨드 이용시
datetime 길이를 3으로 변경
기본값을 0000-00-00 00:00:00.000

상기 소스는 출석부의 랭킹 순서와 연관이 없다.
다만 상기 소스로 정확한 출석 시간을 기록하면 싶다면 적용해 보도록 하자.
그누보드5/eyoom/user_program/page/attendance.php를 열어 // 순위정보 가져오기를 검색한다.

수정 전

                // 순위정보 가져오기
                $rank = sql_fetch("select max(ranking) as max from {$g5['eyoom_attendance']} where atd_datetime like '".$date_day."%'",false);
                $ranking = $rank['max']+1;
수정 후

                // 순위정보 가져오기
                // 랭킹 올바르게
                $rank = sql_fetch("select count(ranking) as rank_no from {$g5['eyoom_attendance']} where atd_datetime like '".$date_day."%' order by atd_datetime asc",false);
                $ranking = $rank['rank_no']+1;

sql_query($sql);를 검색하여 다음과 같이 수정한다.

수정 전

                $sql = "insert into {$g5['eyoom_attendance']} set $set";
                sql_query($sql);
수정 후

                $sql = "insert into {$g5['eyoom_attendance']} set $set";
                sql_query($sql);
추천인 4
  • 내사랑
  • Choco247
  • 아기곰
  • 하늘구장
10
shadow2fox - 회원등급 : 자연/Level 142 - 포인트 : 2,539,218
레벨 142
경험치 3,032,451

Progress Bar 69%

- 가입일 : 2015-03-10 12:21:44
- 서명 : 인간에게 가장 큰 선물은 자기 자신에게 기회를 주는 것이다. - 크리스 가드너, Chris Gardner -
- 자기소개 : There's never a shortcut to happiness.

댓글5

shadow2fox님의 댓글

shadow2fox 글쓴이 2020.01.14 00:08

회원들의 출석 시간 간격이 밀리세컨드(0.001초 ~ 0.009초)의 차이가 날 경우 공동 순위로 DB에 기록이 됩니다. 이는 서버 성능과 연관성이 있는 걸로 추측이 됩니다.

하늘구장님의 댓글

하늘구장 2019.12.16 17:49

기존 소스가 역시나 문제가 있었나 보네요 요번엔 완벽하기를

내사랑님의 댓글

내사랑 @하늘구장 2019.12.16 22:31

요번 건 느낌이 좋음요

내사랑님의 댓글

내사랑 2019.06.16 03:09

백만분의 일 확률로 영자님의 의도하는 바와 다른 결과가 나올 수도 있는 거네요 ㅋ~ 꼼꼼하신 영자님

하늘구장님의 댓글

하늘구장 2019.06.15 12:22

오늘 출석 랭킹이 조금 꼬인 느낌이 나던데 그것 때문에 수정을 보셨나 봐요 퍼가요 ㅎ~

축하합니다. 첫 댓글로 17경험치를 획득하였습니다.