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

짧은주소
-
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

레벨 147
경험치 3,225,027
Progress Bar 12.99%
- 가입일 : 2015-03-10 12:21:44
- 서명 : 인간에게 가장 큰 선물은
자기 자신에게 기회를 주는 것이다.
- 크리스 가드너, Chris Gardner -
- 자기소개 : There's never a shortcut to happiness.
-
[뮤직 비디오 게시판] 이문세 5집 [이문세5] 1988년2025-05-18
-
[공유 자료실] Notepad++ 8.8.12025-05-17
-
[뮤직 비디오 게시판] 사랑했지만 - 김경호 6집 [The Life] 2001년2025-05-16
-
2 [Web Server Tip] 그누보드(영카트) 5.6.13+22025-05-15
-
[골라먹는 요리] 바지락면2025-05-11
-
[좋은 생각] 남의 단점이 꼴보기 싫어질 때2025-05-11
-
[좋은 생각] 마음 가는 대로 해라2025-05-11
-
[좋은 생각] 당신에게 정말 중요한 일을 시작하세요2025-05-11
-
[이슈와 관심] 미약하나마 동참했습니다2025-05-04
-
[생활 정보] 음 180원 다른 운을 기대해봐야겠네요2025-04-26
-
[생활 정보] 나라가 혼돈의 시기를 겪다 보니 봄을 만끽할 겨를 조차 느낄 수 없었네요 정보 감사합니다2025-04-07
-
[생활 정보] 새해 복 많이 받으십시오2025-01-31
-
[자유 게시판] 하늘구장님과 내사랑님 그리고 회원 여러분들 모두의 가정과 일터에 행복과 행운이 가득한 한 해가 되시길 진심으로 기원드립니다 새해 복 많이 받으세요2025-01-27
-
[훈훈과 감동 이야기] 반려자를 옛스럽고 정겹게 표현한 말이 옆지기라고 한다지요 함께 같은 방향을 바라보며 인생을 사는 것이 크나큰 행복이라 생각합니다2025-01-26
-
[이슈와 관심] 페이스북에서 iframe의 부모 페이지에 접근할 수 있도록 CORS(Cross-Origin Resource Sharing) 정책을 설정해줘야 하는 부분이라 이 오류를 해결할 순 없을 것 같습니다 꼼수라면 상단 맨 왼편 프로필 이미지 오른편 포스팅 시간에 마우스 호버를 하게 되면 말풍선이 뜨며 스크립트 오류가 일어나고 그로 인해 제어가 가능해 집니다 참고하세요2025-01-13
-
[생활 정보] 해마다 도움을 받습니다 올해도 감사함을 전합니다2025-01-10
댓글5
shadow2fox님의 댓글
하늘구장님의 댓글
내사랑님의 댓글
내사랑님의 댓글
하늘구장님의 댓글
축하합니다. 첫 댓글로 17경험치를 획득하였습니다.