基于tp5 模型的一个签到功能;

由于存储所有的签到日期数据库会非常庞大,所以签到日期只存储近三个月的。

具体功能:

1、记录最近一次的签到时间

2、每次签到都会添加15积分

3、有连续签到的记录

 CREATE TABLE `sp_sign` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',
`times` datetime DEFAULT NULL COMMENT '最近一次签到时间',
`userid` int(11) DEFAULT NULL COMMENT '用户id',
`days` tinyint(6) NOT NULL DEFAULT '0' COMMENT '连续签到的天数',
`number` decimal(10,0) NOT NULL DEFAULT '0' COMMENT '当月签到给的积分',
`one` varchar(255) DEFAULT NULL COMMENT '当月签到的日期,用“,”隔开',
`two` varchar(255) DEFAULT NULL COMMENT '上个月签到的日期,用“,”隔开',
`three` varchar(255) DEFAULT NULL COMMENT '上上个月签到的日期,用“,”隔开',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;
/**
* 用户签到
* @param array $userid 用户id
*/
public function add($userid)
{
$data = Db::name('sign')->where('userid',$userid)->select();
if(count($data) == 0) //没有该用户的签到记录
{
$query4 = Db::name('sign')->insert(['times'=>date('Y-m-d H:i:s'),'userid'=>$userid,'days'=>1,'number'=>'15','one'=>date('d',time())]);
return 1;
}
else
{
//判断今天是否签到
$todayBegin=date('Y-m-d'." 00:00:00");
$todayEnd= date('Y-m-d'." 23:59:59");
$isexit = Db::name('sign')->field('times')->where(['userid'=>$userid])->where('times','between',[$todayBegin,$todayEnd])->select();
if(count($isexit) == 1) //今日已签到
{
return 0;
}
else //今日未签到
{
$times = Db::name('sign')->where('userid',$userid)->field('times')->select();
$time = strtotime($times[0]['times']); if((time()-$time > 24*60*60)) //上次签到时间大于24小时,连续签到天数清零
{
$query = Db::name('sign')->where('userid',$userid)->update(['days'=>1]);
}
else //上次签到时间小于24小时,连续签到次数加1
{
$query = Db::name('sign')->where('userid',$userid)->setInc('days');
}
//更新上次签到时间和签到积分
$query1 = Db::name('sign')->where('userid',$userid)->update(['times'=>date('Y-m-d H:i:s')]);
$query2 = Db::name('sign')->where('userid',$userid)->setInc('number', 15); $sqldate = date('m',$time); //上次签到日期的月份
$nowdate = date('m',time()); //当前月份
//记录本次签到日期
if($sqldate != $nowdate) //上次签到日期与本次签到日期月份不一样
{
$oldtime = $times[0]['times'];
$onetime=date("Y-m-d H:i:s", strtotime("-1 month")); //获取前1个月的时间,获取格式为2016-12-30 13:26:13
$twotime=date("Y-m-d H:i:s", strtotime("-2 month")); //获取前2个月的时间
$threetime=date("Y-m-d H:i:s", strtotime("-3 month")); //获取前3个月的时间 $rs = Db::name('sign')->where('userid',$userid)->field('one,two,three')->select(); if($oldtime < $onetime && $oldtime >= $twotime) //月份间隔 大于1个月,小于2个月
{
$one = date('d',time());
$two = $rs[0]['one'];
$three = $rs[0]['two'];
}
elseif($oldtime < $twotime && $oldtime >= $threetime) //月份间隔 大于2个月,小于3个月
{
$one = date('d',time());
$two = '';
$three = $rs[0]['one'];
}
elseif($oldtime < $threetime) //月份间隔 大于3个月
{
$one = date('d',time());
$two = '';
$three = '';
}
$query3 = Db::name('sign')->where('userid',$userid)->update(['one'=>$one,'two'=>$two,'three'=>$three]);
}
else //上次签到日期与本次签到日期月份一样
{
$one = Db::name('sign')->where('userid',$userid)->field('one')->select();
$arr[] = $one[0]['one'];
$arr[] = date('d',time());
$newones = implode(",",$arr);
$query3 = Db::name('sign')->where('userid',$userid)->update(['one'=>$newones]);
}
return 1;
}
}
}
 

over!over!over!

 

TP5实现签到功能的更多相关文章

  1. 使用 UICollectionView 实现日历签到功能

    概述 在 App 中,日历通常与签到功能结合使用.是提高用户活跃度的一种方式,同时,签到数据中蕴含了丰富的极其有价值的信息.下面我们就来看看如何在 App 中实现日历签到功能. 效果图 ..... 思 ...

  2. (三)开始在OJ上添加签到功能

    在了解完OJ文件下的各个文件夹的主要作用后,我们开始往里面添加东西(其实只要知道各文件夹是干什么的后,添加东西也变得非常简单了) 一 在数据库中添加对应功能的字段. 我们这个学期才刚开数据库这门课,所 ...

  3. Redis位图实现用户签到功能

    场景需求 适用场景如签到送积分.签到领取奖励等,大致需求如下: 签到1天送1积分,连续签到2天送2积分,3天送3积分,3天以上均送3积分等. 如果连续签到中断,则重置计数,每月初重置计数. 当月签到满 ...

  4. 基于Redis位图实现用户签到功能

    场景需求 适用场景如签到送积分.签到领取奖励等,大致需求如下: 签到1天送1积分,连续签到2天送2积分,3天送3积分,3天以上均送3积分等. 如果连续签到中断,则重置计数,每月初重置计数. 当月签到满 ...

  5. 使用flask搭建微信公众号:实现签到功能

    终于到了实战阶段.用微信公众号实现一个简单的签到功能. 前情提要: 微信公众号token验证失败 使用flask搭建微信公众号:完成token的验证 使用flask搭建微信公众号:接收与回复消息 程序 ...

  6. Redis实战篇(二)基于Bitmap实现用户签到功能

    很多应用上都有用户签到的功能,尤其是配合积分系统一起使用.现在有以下需求: 签到1天得1积分,连续签到2天得2积分,3天得3积分,3天以上均得3积分等. 如果连续签到中断,则重置计数,每月重置计数. ...

  7. php实现签到功能

    首先我在数据库里建了两张表,一个是用户的积分表,一个是签到状态表,分来用来记录用户的积分数和先到状态 在用户签到状态表中我们有一个字段,last_sign_time,即上一次签到时间,每次可以签到的时 ...

  8. H5 签到功能

    Introduce(介绍) 用户签到的H5例子(css+jquery,无图片),由于网上找的的用户签到例子都不好,要不就是好多图片组成的,要不就大量冗余代码,所以特意做了个签到界面(移动端). Use ...

  9. 签到功能,用 MySQL 还是 Redis ?

    现在的网站和app开发中,签到是一个很常见的功能,如微博签到送积分,签到排行榜. 如移动app ,签到送流量等活动.   用户签到是提高用户粘性的有效手段,用的好能事半功倍! 下面我们从技术方面看看常 ...

随机推荐

  1. speechSynthesis,TTS语音合成。

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. MacBook Pro使用初体验之Mac快捷键汇总(持续更新中)

    我于近日购置了一台13寸的MacBook Pro高配,打算開始进行iOS开发的学习.Pro的配置情况例如以下: (1)OS X Yosemite ,版本号10.10.3 (2)Retina显示屏,13 ...

  3. 【SVN版本回退】

    [SVN版本回退]根据想要回退的内容,然后选择revert to this revision或者revert changes from this revision.下面引用过来:譬如有个文件,有十个版 ...

  4. SpringInAction4笔记——复习

    由于目前只做后端的业务代码的开发,所以根据自己掌握的熟悉程度,只需要复习几个模块即可 重点看的是核心容器(IOC),redis,缓存,消息(主要是rabbitmq),事务,springboot,单元测 ...

  5. Java类加载器(死磕5)

    Java类加载器(  CLassLoader )  死磕5:  自定义一个文件系统classLoader 本小节目录 5.1. 自定义类加载器的基本流程 5.2. 入门案例:自定义文件系统类加载器 5 ...

  6. Transforming Auto-encoders

    http://www.cs.toronto.edu/~hinton/absps/transauto6.pdf The artificial neural networks that are used ...

  7. Routine Subroutine Coroutine 子程序 协程

    https://en.wikipedia.org/wiki/Subroutine In computer programming, a subroutine is a sequence of prog ...

  8. C++笔记之外部类访问内部类的私有成员

    如下图所示 内部类可以访问外部类的私有成员 而外部类无法访问内部类的私有成员 为了能让外部类访问内部类的私有成员,将外部类声明为内部类的友元类即可 #include <iostream> ...

  9. 浅淡!important对CSS的重要性

    SS中的!important是一个非常重要的属性,有时候发挥着非常大的作用,52CSS.com这方面的知识并不是非常多,我们看下面的文章,对它作比较感观的了解. 前几天写一些CSS代码的时候又难为我了 ...

  10. 持续集成工具hudson【转载】

    第一节 我的理解 项目中使用了hudson,那么hudson是处在怎样的一个地位呢? 首先就我自己的认知,项目中hudson的作用有一下几点: 1.获取svn服务器上的最新代码: 2.把最新代码编译打 ...