[이윰] 출석부 랭킹 중복 방지하기
페이지 정보
shadow2fox
2,925 5 4
2019.12.16 17:33
짧은주소
-
https://yadolee.com/tip/658 주소복사
평점
본문
출석부 랭킹 중복 방지하기
이윰빌더에서 판매하는 출석부는 그누보드에 정의된 시간상수를 통해 출석시간을 초단위로 DB에 저장하는데 회원들이 동시다발적으로 출석을 하게 되면 중복순위가 나오기 마련이고 그로인해 랭킹 순위와 선착순 순위가 의도치 않는 결과를 야기함으로 출석시간이 밀리세컨드(milliseconds, 천분의 1초) 혹은 마이크로세컨드(microseconds, 백만분의 1초)로 저장되도록 수정해 보자.
아래 예제는 마이크로세컨드(microseconds) 사용시
1. 그누보드5/eyoom/user_program/page/attendance.php를 열어 // 내용글은 텍스트 필터를 검색한다.
수정 전
atd_datetime = '".G5_TIME_YMDHIS."'를 검색하여 다음과 같이 수정한다.
수정 전
atd_datetime` datetime NOT NULL default '0000-00-00 00:00:00',를 검색하여 다음과 같이 수정한다.
수정 전
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를 열어 // 순위정보 가져오기를 검색한다.
수정 전
sql_query($sql);를 검색하여 다음과 같이 수정한다.
수정 전
아래 예제는 마이크로세컨드(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
레벨 142
경험치 3,030,224
Progress Bar 64%
- 가입일 : 2015-03-10 12:21:44
- 서명 : 인간에게 가장 큰 선물은
자기 자신에게 기회를 주는 것이다.
- 크리스 가드너, Chris Gardner -
- 자기소개 : There's never a shortcut to happiness.
-
2 [Web Server Tip] 그누보드(영카트) 5.5.16+22024-04-18
-
1 [짤방 게시판] 이소무라 미우 - 주간 플레이보이 2024 No.8•92024-04-13
-
1 [짤방 게시판] 시로마 나나미 - 주간 플레이보이 2024 No.8•92024-04-13
-
1 [짤방 게시판] 아소 카온 - 주간 플레이보이 2024 No.8•92024-04-13
-
1 [짤방 게시판] 모리 카스미 - 주간 플레이보이 2024 No.8•9+12024-04-13
-
1 [짤방 게시판] 이마모리 마야 - 주간 플레이보이 2024 No.8•92024-04-13
-
2 [Web Server Tip] 그누보드(영카트) 5.5.15+22024-04-12
-
3 [자유 게시판] 의미심장한 선택 2024 MBC 선거 방송+22024-04-10
-
[자유 게시판] 부활 곡에 잘 어울릴 듯 한 보이스 컬러네요 동감입니다2024-03-31
-
[생활 정보] 80원의 행복이네요{이모티콘}2024-03-21
-
[자유 게시판] 같은 의견이에요2024-03-14
-
[자유 게시판] 다시 봐도 감동입니다{이모티콘}2024-03-11
-
[자유 게시판] 제가 라이브 시청을 하지 않아야 대활약을 해서 손흥민 선수를 위해 안타깝지만 자제 중입니다{이모티콘} 반더벤 또한 너무 잘하지 않았나 싶었네요2024-03-03
-
[자유 게시판] 하늘구장님 늘 감사드리며 마음을 담아 새해 인사를 전합니다 새해 복 많이 받으세요2024-02-09
-
[이슈와 관심] 최소 누군가는 가학 대통령으로 기억할 것 같습니다2024-01-29
-
[이슈와 관심] {글:링크} 배추도 매출도 아닌 배출로 들려서... 한동안 또 시끄러울 것 같습니다.2024-01-28
댓글5
shadow2fox님의 댓글
회원들의 출석 시간 간격이 밀리세컨드(0.001초 ~ 0.009초)의 차이가 날 경우 공동 순위로 DB에 기록이 됩니다. 이는 서버 성능과 연관성이 있는 걸로 추측이 됩니다.
하늘구장님의 댓글
기존 소스가 역시나 문제가 있었나 보네요 요번엔 완벽하기를
내사랑님의 댓글
요번 건 느낌이 좋음요
내사랑님의 댓글
백만분의 일 확률로 영자님의 의도하는 바와 다른 결과가 나올 수도 있는 거네요 ㅋ~ 꼼꼼하신 영자님
하늘구장님의 댓글
오늘 출석 랭킹이 조금 꼬인 느낌이 나던데 그것 때문에 수정을 보셨나 봐요 퍼가요 ㅎ~
축하합니다. 첫 댓글로 17경험치를 획득하였습니다.