来源 | http://suo.im/5EWN3k

今天,看下签到功能怎么选择?

现在的网站和app开发中,签到是一个很常见的功能,如微博签到送积分,签到排行榜~

微博签到

如移动app ,签到送流量等活动,移动app签到

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

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

一. 方案1

直接存到数据库MySQL

用户表如下:last_checkin_time 上次签到时间

checkin_count 连续签到次数

记录每个用户签到信息

签到流程

1.用户第一次签到

last_checkin_time = time()checkin_count=1

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

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

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

a.昨天也有签到

last_checkin_time = time()checkin_count= checkin_count+1

b.昨天没有签到

last_checkin_time = time()checkin_count=1

使用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->last_checkin_time = time();  $model->checkin_count = 1; }}$rs = $model->save();

二. 方案2

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

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

count=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 服务器被阻塞;所以要考虑切分。

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

看完本文有收获?点赞、分享是最大的支持!

简单的签到代码_PHP实现一个小小的签到功能,到底用MySQL还是Redis?相关推荐

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

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

  2. 简单的签到代码_签到功能,用 MySQL 还是 Redis ?

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

  3. 投票应用是用mysql还是redis_签到功能,用 MySQL 还是 Redis?

    本文转载自[微信公众号:java进阶架构师,ID:java_jiagoushi]经微信公众号授权转载,如需转载与原文作者联系 用户签到是提高用户粘性的有效手段,用的好能事半功倍! 下面我们从技术方面看 ...

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

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

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

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

  6. 20分钟,我用简单的Python代码创建了一个完整的区块链!想学吗?

    作者 | Gerald Nash 编译 | 科科.kou.木星 这是篇技术文,我们会用Python一步步搭建一个完整的区块链.不过,在此之前,咱们还是先说说你什么你该学习如何从零搭建一个区块链. 有人 ...

  7. 简单几行代码,写一个百度广告屏蔽插件,爽到爆

    下载地址:https://github.com/jsoncode/b... 使用方法: 将文件夹拖到这里面 一个小问题: 我没有境外支付信用卡>无法向谷歌支付$5的费用>每次打开浏览器都会 ...

  8. java写一个简单的浪漫代码_求一个简单但是浪漫的表白方法!!

    鲜花表白 只要和爱情沾边儿那都离不开玫瑰花,所以最简单的方式就是用玫瑰花表白,玫瑰花表白可以体现在数量上,有送一朵的,有送十一朵的,又送三十三朵,还有送九十九朵的.除此之外,还可以摆鲜花阵表白,一般情 ...

  9. 从零开始实现一个简单的低代码编辑器

    一.写在前面 低代码编辑器作为一种能够极大地提升开发效率的 PaaS 软件,近些年来一直收到各大公司以及各路投资方的追捧.而对于我们前端开发者来说,编辑器也是为数不多的拥有较深前端技术深度的开发场景. ...

最新文章

  1. 提供第三种代码生成方式——通过自定义BuildProvider为ASP.NET提供代码生成
  2. 程序员学霸!top2大学毕业!不到30岁第一次升P9失败!挫折感极强,怀疑人生?网友:没升P7的我,不要面子的吗??...
  3. python接口测试框架设计_Python3简易接口自动化测试框架设计与实现(中)
  4. C#中使用MD5对用户密码加密与解密
  5. 【MFC系列-第32天】控件自绘技术
  6. 前端学习(1777):前端调试之websql原理和查看
  7. MyBatisPlus自动生成代码springboot+mybatis+mysql 以及动态sql生成方法(测试可用版)
  8. 【HTML5】Web存储、通信、地理位置
  9. 项目管理系统Redmine安装
  10. java图片去掉文字,Java 移除html,图片 链接转文字
  11. javascript实现silverlight pivotViewer控件
  12. Java-虚拟机-执行引擎/解释器/编译
  13. c++类的成员函数作回调函数为啥要声明为static的
  14. google erath api v3 与v2版本在定位方面的区别
  15. SQL教程(从入门到精通)
  16. ABB变频器维修,ABB变频器,ABB变频器配件FS300R12KE3/AGDR-61C 驱动模块APOW-01C 电源板AINP-01C 可控硅触发板
  17. 高德地图通过经纬度获取位置信息
  18. R语言入门与数据分析(2)
  19. 洪水填充算法_计算机图形:洪水填充算法
  20. TCP连接建立的步骤

热门文章

  1. C++多重继承师生类复盘
  2. antd 进行ajax请求,react+dva+antd接口调用方式
  3. QtCreate不能使用代码提示功能
  4. mysql dump 数据时间_使用mysqldump备份数据及做时间点还原测试步骤
  5. C语言实现动态顺序表
  6. [LCP28] 采购方案
  7. mysql里面可以用正则吗_Mysql中使用正则表达式
  8. java boolean是什么_java中的boolean与Boolean有什么不同
  9. 如何设置计算机http端口号,服务器http端口设置
  10. 正面管教php_中联重科团委快乐父母协会第五期正面管教家长基础班招募!