> 백엔드 개발 > PHP 튜토리얼 > 数据库,连续的签到系统怎么设计?

数据库,连续的签到系统怎么设计?

WBOY
풀어 주다: 2016-06-06 20:28:34
원래의
2835명이 탐색했습니다.

背景:对连续签到的系统进行递级给积分,并且连续签到有一定的积分奖励,并且用户连续签到30天给比较多的积分。

要求:并不是按照自然月来签到。

  1. 怎么判断是不是连续签到呢?

  2. 然后就是数据库怎么设计好呢,因为并不是按照自然月来签到,连续签到的话都是跨月的了。

回复内容:

背景:对连续签到的系统进行递级给积分,并且连续签到有一定的积分奖励,并且用户连续签到30天给比较多的积分。

要求:并不是按照自然月来签到。

  1. 怎么判断是不是连续签到呢?

  2. 然后就是数据库怎么设计好呢,因为并不是按照自然月来签到,连续签到的话都是跨月的了。

记录一个人当次连续第1天的日期和最后1天的日期,签到的时候判断是否连续。如果连续,可以计算出来连续天数。如果不连续,重置连续第1天和最后1天的日期为当前签到日期。

如果需要记录签到,专门用一张表来记录。可以按月,即每一月一条数据来记录,也可以按年记录。如果按天记录的话数据量太大,没啥必要。

这个数据库设计不想的太复杂,签到系统其实逻辑判断比较重要。我前几天刚好做了一个,只需要把时间格式化,去掉时分秒,如20150907,之后的话只需要判断前边的几天时间记录是否相邻即可。

一个字段记录连续签到次数,一个字段记录最后一次签到的时间!
每次签到
判断:检查上次签到时间和现在的签到时间中间是否为1天
是:

<code>签到次数+1;</code>
로그인 후 복사

不是:

<code>签到次数=0</code>
로그인 후 복사

更新最后的签到时间为现在时间;

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿