之前发过一篇:点赞功能用mysql还是redis​mp.weixin.qq.com

?受到大家喜欢,今天看下签到功能怎么选择?

现在的网站和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

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 签到_签到功能,用mysql还是redis?相关推荐

  1. 零点起飞学mysql视频_零点起飞学MySQL

    第1篇 MySQL基础 第1章 数据库的安装(教学视频:25分钟) 2 1.1 MySQL概述 2 1.1.1 MySQL特性以及历史 2 1.1.2 MySQL的获取 3 1.2 MySQL的安装 ...

  2. 打开和关闭mysql服务器_启动和关闭MySQL服务器

    欢迎进入Linux社区论坛,与200万技术人员互动交流 >>进入 作为MySQL管理员,一个普通的目标就是确保服务器尽可能地处于运行状态,使得客户机能够随时访问它.但是,有时最好关闭服务器 ...

  3. jdbc连接云数据库mysql数据库_使用jdbc连接mysql数据库

    {"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],&q ...

  4. golang mysql 崩溃_使用GoLang与mysql连接失败

    我试图使用Go语言连接MySql数据库并给我以下错误. sql: unknown driver "mysql" (forgotten import?) 我的守则 package m ...

  5. navicat mysql 日志_使用Navicat查看MySQL日志的具体方法

    使用Navicat查看MySQL日志的具体方法 发布时间:2020-05-18 14:04:52 来源:51CTO 阅读:699 作者:三月 下文主要给大家带来使用Navicat查看MySQL日志的具 ...

  6. mysql密码@_如何重设MySQL密码

    展开全部 方法一 使用phpmyadmin,这是最简单的了,修改mysql库的user表,不过别62616964757a686964616fe78988e69d8331333361313936忘了使用 ...

  7. pdo连接mysql 注入_使用PDO查询mysql避免SQL注入

    使用传统的 mysql_connect .mysql_query方法来连接查询数据库时,如果过滤不严紧,就有SQL注入风险.虽然可以用mysql_real_escape_string()函数过滤用户提 ...

  8. excel读取mysql数据库_我有一个mysql数据库,现在想通过excel电子表格读取里面的数据,需要怎么操作?...

    我自用的excel2016连接mysql的经验 1. VBA连接MySQL前的环境配置 1.1 开启OFFICE2016各个功能: 1. 开发工具的开启 点击"文件"---&quo ...

  9. centos 查看mysql 服务器配置_在CentOS上MySQL数据库服务器配置方法

    http://www.jb51.net/article/23255.htm ======================== 1 . 无密码登录: mysql -u root 在已经有密码的情况下报错 ...

最新文章

  1. Swift-学习Perfect搭建博客
  2. 数据库系统概论:第一章 绪论
  3. linux创建表空间 没有权限,Linux oracle数据库创建表空间、用户并赋予权限
  4. Android httpUrlConnection的基本使用
  5. c语言中1B是多少,C语言1、C语言中,运算对象必须是整型的运算符是【】A./B-查字典问答网...
  6. 部署:持续集成(CI)与持续交付(CD)——《微服务设计》读书笔记
  7. Revit2018找不到外部工具
  8. 英特尔西安团队将被裁撤 波及约200人?回应...
  9. 点击按钮刷新_Chrome扩展推荐:抢票太累?后台监视网页,页面自动刷新和提醒...
  10. 我们团队有个做风水项目的现在月收入也有几万了
  11. html5制作前端优势,HTML5前端开发原来有这么多优势!
  12. 安卓帧数监测软件_还在用游戏加加看帧数?驴哥教你怎么用微星小飞机的硬件监测功能...
  13. Selenium 三种等待
  14. 万能DLL1.3发布 ——您的编程好帮手
  15. 计算机网络中ipv6什么意思,路由器ipv6是什么意思(图文)
  16. untracked files prevent merge
  17. MacOS破解WiFi(WPA、WPA2)
  18. 使用Aspose Java在word中绘制插入表格
  19. Android轻松实现分享功能
  20. SQL Server2019(Developer版)免费下载安装教程

热门文章

  1. AMD首款5纳米PC处理器锐龙7000亮相,频率首破5GHz大关,单核性能提升15%
  2. RF自动化测试系列-第三篇 测试数据
  3. 多媒体——音频——使用录音机录制音频
  4. cesium 相机跟随
  5. Linux没有网怎么解决。
  6. 关于spacing和重采样、降采样的理解
  7. js 字符串格式化format函数扩展
  8. HDOJ 1859 最小长方形
  9. 修复WHS中缺少的外部硬盘数据库错误
  10. 这些用例设计题,你在面试时遇到过吗?