本文转载自【微信公众号:java进阶架构师,ID:java_jiagoushi】经微信公众号授权转载,如需转载与原文作者联系

用户签到是提高用户粘性的有效手段,用的好能事半功倍!

下面我们从技术方面看看常用的实现手段:

一. 方案1

直接存到数据库MySQL

用户表如下:

last_checkin_time上次签到时间

checkin_count 连续签到次数

记录每个用户签到信息

签到流程

1.用户第一次签到

last_checkin_time = time()

checkin_count=1

2.用户非第一次签到,且当天已签到

什么也不做,返回已签到。

3.用户非第一次签到,且当天还未签到

a.昨天也有签到

checkin_count= checkin_count+1

b.昨天没有签到

使用yii实现的代码如下:

//0点

$today_0 = strtotime(date('y-m-d'));

//昨天0点

$yesterday_0 = $today_0-24*60*60;

$last_checkin_time = $model->last_checkin_time;if(empty($last_checkin_time)){

//first checkin

$model->last_checkin_time = time();

$model->checkin_count = 1;

}else{

if($today_0 < $last_checkin_time){

//checkin ed 当天已签到过

return json_encode(['code' => 0, 'msg' => '已签到成功']);

} //昨天签到过 if($last_checkin_time < $today_0 && $last_checkin_time > $yesterday_0){

$model->last_checkin_time = time();

$model->checkin_count = $model->checkin_count + 1;

}else{

//昨天没签到过,重新计数

$model->checkin_count = 1;

}}$rs = $model->save();

二. 方案2

redis实现方案,使用bitmap来实现,bitmap是redis 2.2版本开始支持的功能,一般用于标识状态,

另外 ,用bitmap进行当天有多少人签到非常的方便,使用bitcount

redis->BITCOUNT($key);

设置两个bitmap ,

一个以每天日期为key ,每个uid为偏移量一个以用户uid为key ,当天在一年中的索引为偏移量,这样记录一个用户一年的签到情况仅需要365*1bit

以下是签到代码

//每天一个key

$key = 'checkin_' . date('ymd');

if($redis->getbit($key, $uid)){

//已签到 return json_encode(['code' => 0, 'msg' => '已签到成功']);

}else{

//签到 $redis->setbit($key, $uid, 1);

$redis->setbit('checkin_'.$uid , date('z'), 1);

}

以下是用户连续签到计算

public static function getUserCheckinCount($uid){

$key = 'checkin_'.$uid;

$index = date('z');

$n = 0;

for($i = $index; $i>=0;$i--){

$bit = Yii::$app->redis->getbit($key, $i); if($bit == 0) break;

$n++; } return $n;

}

以下是计算一天签到用户数

$key = 'checkin_' . date('ymd');

$redis = Yii::$app->redis;$count = $redis->BITCOUNT($key);

还有什么需求呢?可以自己试着去实现

三. 优缺点比较

1.直接MySQL

思路简单,容易实现;

缺点:占用空间大,表更新比较多,影响性能,数据量大时需要用cache辅助;

2.Redis bitmap

优点是:

占用空间很小,纯内存操作,速度快;

缺点是 :

记录的信息有限,只有一个标识位;

偏移量不能大于2^32,512M;大概可以标识5亿个bit位,绝大多数的应用都是够用的啦;

偏移量很大的时候可能造成 Redis 服务器被阻塞;所以要考虑切分。

好啦,两种方式介绍完了,各有利弊,你喜欢哪种方式呢?

欢迎讨论!

投票应用是用mysql还是redis_签到功能,用 MySQL 还是 Redis?相关推荐

  1. php mysql实现每日签到积分_php+mysql+jquery实现日历签到功能

    在网站开发过程中我们会经常用到签到功能来奖励用户积分,或者做一些其他活动.这次项目开发过程中做了日历签到,因为没有经验所有走了很多弯路,再次记录过程和步骤. 1.日历签到样式: 2.本次签到只记录本月 ...

  2. mysql怎么做每天签到_MYSQL实现连续签到功能断签一天从头开始(sql语句)

    1,创建测试表 create table `testsign` ( `userid` int(5) default null, `username` varchar(20) default null, ...

  3. 聊天记录存redis还是mysql_一个小小的签到功能,到底用MySQL还是Redis?

    今天,看下签到功能怎么选择? 现在的网站和app开发中,签到是一个很常见的功能,如微博签到送积分,签到排行榜~ 微博签到 如移动app ,签到送流量等活动, 移动app签到 用户签到是提高用户粘性的有 ...

  4. mysql 连续签到天数_签到功能实现,没有你想的那么复杂(一)

    1 签到定义以及作用签到,指在规定的簿册上签名或写一"到"字,表示本人已经到达.在APP中使用此功能,可以增加用户粘性和活跃度.2 技术选型redis为主写入查询,mysql辅助查 ...

  5. 简单的签到代码_PHP实现一个小小的签到功能,到底用MySQL还是Redis?

    来源 | http://suo.im/5EWN3k 今天,看下签到功能怎么选择? 现在的网站和app开发中,签到是一个很常见的功能,如微博签到送积分,签到排行榜~ 微博签到 如移动app ,签到送流量 ...

  6. mysql 签到_签到功能,用mysql还是redis?

    之前发过一篇:点赞功能用mysql还是redis​mp.weixin.qq.com ?受到大家喜欢,今天看下签到功能怎么选择? 现在的网站和app开发中,签到是一个很常见的功能 如微博签到送积分,签到 ...

  7. 日历签到 mysql_php+mysql+jquery实现日历签到功能的方法

    本文主要介绍了php+mysql+jquery实现日历签到功能的过程与步骤,具有很好的参考价值 在网站开发过程中我们会经常用到签到功能来奖励用户积分,或者做一些其他活动.这次项目开发过程中做了日历签到 ...

  8. php mysql ajax日历记事本_php+mysql+jquery日历签到

    在网站开发过程中我们会经常用到签到功能来奖励用户积分,或者做一些其他活动.这次项目开发过程中做了日历签到,因为没有经验所有走了很多弯路,再次记录过程和步骤.1.日历签到样式:2.本次签到只记录本月签到 ...

  9. php mysql连续签到跨月_PHP连续签到功能实现方法详解

    本文实例讲述了PHP连续签到功能实现方法.分享给大家供大家参考,具体如下: require "./global.php"; $act = isset($_GET['act']) ? ...

最新文章

  1. 资金只够支撑10个月,自动驾驶致命事故重演:特斯拉陷入困境
  2. 买卖股票的最佳时机||
  3. Flask初识,第五篇 ,做一个用户登录之后查看学员信息的小例子
  4. 什么是java dom_java web--DOM
  5. Venn网络展示富集分析结果
  6. 使用 Adobe AIR 管理 WordPress 评论
  7. SVN和Git 介绍,区别,优缺点,适用范围总结
  8. 阿里云混合云新一代运维平台的演进与实践
  9. 基于php+Mysql新闻管理系统 开题报告
  10. Delphi教程推荐
  11. DGIOT 工业物联网开源平台简介
  12. HTML5和CSS3的一些小总结
  13. 【操作系统习题】假定某多道程序设计系统供用户使用的主存空间为100 KB ,磁带机2台,打印机1台
  14. sk_buff属性详解
  15. 英雄传奇-1.专用浏览器问题
  16. 计算机的创新知识,创新高中计算机知识学习的策略分析
  17. torch.norm-L2范数
  18. TokenUtil工具类(生成token和解析token)
  19. golang 初始化并赋值_嵌套Golang对象的初始化
  20. 不用写代码,用表格居然能开发软件和APP

热门文章

  1. 如何迎接新的 .NET 时代
  2. oracle建表 和 设置主键自增
  3. Comparable和Comparator
  4. Selenium2+python自动化8-SeleniumBuilder辅助定位元素
  5. CloudStack 4.4+KVM之通过ISO文件创建CentOS虚拟机
  6. Castle.Aop.Autofac
  7. 一道海量日志的随机选取问题
  8. trados 2007 2009 共用一个LICENSE服务器
  9. OpenCV-浮雕雕刻效果
  10. linux远程无密码登录,linux ssh无密码登录,远程执行脚本文件