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

WBOY
リリース: 2016-06-06 20:28:34
オリジナル
2794 人が閲覧しました

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

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

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

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

回复内容:

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

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

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

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

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

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

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

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

<code>签到次数+1;</code>
ログイン後にコピー

不是:

<code>签到次数=0</code>
ログイン後にコピー

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

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!