mysql 连续签到天数_获取连续登陆天数,连续签到天数 ,方法优化

获取连续登陆天数,连续签到天数,类似这样的需求应该是一个常见的需求,那么我们有没有一套成熟的解决方案呢 ?下面我来跟大家分享一下我的故事。

在猴年马月的一天,有个用户反馈个人中心打开缓慢,需要7、8秒,做为一个认真负责任的程序员GG,我尼玛放下手中的其他工作,跟踪调查并且解决该问题。

第一步重现问题:

连着登陆了好几个账号到个人中心,打开都不慢呀 ,那是什么问题呢,就你一个人出问题,是你人品差吧,正当打算以此敷衍用户的时候,测试组的小陶说,他也遇到了这个问题,纳尼 !!你个人品差的家伙 ,让俺来看看,你要重现不了,看我不打死你。 于是他登陆账号试了一下,果然是有些缓慢,大概在4、5秒的样子,嗯,至此,这个问题重现成功了 。嗯,厉害 。

第二步查找问题根本原因:

总不是这两个人人品都差吧,经过一番严密的调查,问题最终锁定在获取连续签到次数上,别问我怎么查到的,因为这两个奇葩居然做到连续签到近100天的牛逼战绩,然后获取连续签到的存储过程采用的循环算法是连续登陆天数越多,算法复杂度就越高。下面贴存储过程代码:

1 --循环法

declare @day int = 1, --2 @userId int =1, --用户id

3 @count int = 0 , --连续签到多少天

4 @isSinginToday int --今天是否签到

5

6

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用 MySQL 的日期函数和子查询实现连续日期统计,具体步骤如下: 1. 构造一个包含所有需要统计的日期的临时表,可以使用 UNION ALL 来实现,例如统计从 2022-01-01 到 2022-01-31 的日期: ``` SELECT DATE('2022-01-01') AS date UNION ALL SELECT DATE('2022-01-02') UNION ALL SELECT DATE('2022-01-03') ... UNION ALL SELECT DATE('2022-01-31'); ``` 2. 使用子查询查询连续出现的天数,首先需要找到每个连续日期段的起始日期和结束日期,可以通过自连接的方式实现。假设有一个名为 `date_table` 的表存储了所有需要统计的日期,可以使用以下 SQL 语句查询连续日期段: ``` SELECT a.date AS start_date, MIN(c.date) AS end_date FROM date_table a LEFT JOIN date_table b ON b.date = DATE_SUB(a.date, INTERVAL 1 DAY) LEFT JOIN date_table c ON c.date = DATE_ADD(a.date, INTERVAL 1 DAY) WHERE b.date IS NULL OR c.date IS NULL GROUP BY a.date; ``` 上述 SQL 语句会找到所有连续出现的日期段的起始日期和结束日期,例如: ``` +------------+------------+ | start_date | end_date | +------------+------------+ | 2022-01-01 | 2022-01-01 | | 2022-01-02 | 2022-01-03 | | 2022-01-04 | 2022-01-04 | | 2022-01-07 | 2022-01-08 | | 2022-01-09 | 2022-01-09 | | 2022-01-10 | 2022-01-10 | +------------+------------+ ``` 3. 使用上一步查询到的连续日期段,结合日期函数和 GROUP BY 子句,统计每个连续日期段内的天数: ``` SELECT start_date, end_date, COUNT(*) AS count FROM ( SELECT a.date AS start_date, MIN(c.date) AS end_date FROM date_table a LEFT JOIN date_table b ON b.date = DATE_SUB(a.date, INTERVAL 1 DAY) LEFT JOIN date_table c ON c.date = DATE_ADD(a.date, INTERVAL 1 DAY) WHERE b.date IS NULL OR c.date IS NULL GROUP BY a.date ) AS t JOIN date_table d ON d.date BETWEEN t.start_date AND t.end_date GROUP BY start_date, end_date; ``` 上述 SQL 语句会输出每个连续日期段的起始日期、结束日期和连续出现的天数,例如: ``` +------------+------------+-------+ | start_date | end_date | count | +------------+------------+-------+ | 2022-01-01 | 2022-01-01 | 1 | | 2022-01-02 | 2022-01-03 | 2 | | 2022-01-04 | 2022-01-04 | 1 | | 2022-01-07 | 2022-01-08 | 2 | | 2022-01-09 | 2022-01-09 | 1 | | 2022-01-10 | 2022-01-10 | 1 | +------------+------------+-------+ ``` 注意,上述 SQL 语句中的 `date_table` 表需要根据实际情况替换为实际的表名或子查询

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值