专栏首页码农小胖哥的码农生涯mysql如何进行累加计算

mysql如何进行累加计算

01、前言

接了一个需求,产品想分析一下用户增长的曲线。也就是某个时间段的每日总人数列表。好对近期活动进行一个效果的评测。这个统计sql还是花了我一小段时间的。mysql统计这个还是需要一定的技巧的。

02、需求分析

user_id

reg_time

1

2019-09-03

2

2019-09-04

3

2019-09-04

4

2019-09-05

5

2019-09-05

6

2019-09-06

假如上表为user_info,我们很容易根据时间维度统计出每日新增的人数。sql如下:

select reg_time, count(user_id) daily_quantityfrom user_infogroup by reg_time

通过上面的sql我们很容易得出以下列表:

reg_time

daily_quantity

2019-09-03

1

2019-09-04

2

2019-09-05

2

2019-09-06

1

但是这个并不是我们想要的结果。我们想要的应该是 上一天的总人数加上今天的净增长数,以此类推。下面才是我们想要的结果:

reg_time

daily_quantity

2019-09-03

1

2019-09-04

3

2019-09-05

5

2019-09-06

6

这就有点棘手了,我们需要进行累加计算。我尝试了自链接,函数等一些操作后还是没有得到一个正确的结果。这时想到如果是java代码处理这个就再合适不过了,我们只要声明初始值,然后循环累加就能计算出结果了:

public static void main(String[] args) {    int[] arr = {1, 2, 2, 1};    int[] ints = dailyQuantityArr(0, arr);  for (int i : ints) {    System.out.println("i = " + i);  }}public static int[] dailyQuantityArr(int base, int[] dailyIncrQuantity) {    int[] result = new int[dailyIncrQuantity.length];    // 累加填充    for (int i = 0; i < dailyIncrQuantity.length; i++) {      base += dailyIncrQuantity[i];      result[i] = base;    }    return result;}

上面的伪代码就可以计算出结果。当然如果可以的话尽量在java业务代码进行这种复杂运算。但是产品给出的需求是我们能够提供一句sql能够直接在可视化数据引擎中得出他要的答案。于是从上面的代码得出灵感。

mysql是否有这种变量呢?有!当然有。记得很普遍的场景,以前经常有业务需要我们输出序号,Oracle是自带一个伪列rownum,但是mysql没有。mysql通常通过声明自增变量来生成序号。拿user_info表举例子:

select (@i:=@i+1) as rownum, user_idfrom user_info ,(select @i:=0) as r

03、Mysql 用户变量

mysql 变量分为 局部变量、用户变量、会话变量、全局变量 。上面的语句我们使用的是用户变量。用户变量与数据库连接有关,在连接中声明的变量,在存储过程中创建了用户变量后一直到数据库实例接断开的时候,变量就会消失。在此连接中声明的变量无法在另一连接中使用。

MySQL中用户变量不用事前申明,使用的时候以@varname的格式进行声明。通过 := 或者 = 进行赋值操作。如果需要对外输出需要用 select 关键字,而且赋值必须使用 := 符号。

04、Mysql累加计算

我们学习了用户变量后就知道如何进行累加计算了,那么user_info表的日累计总人数应该是这样的:

select a.reg_time,        a.daily,        @i:=@i+a.daily as daily_quantity     from (select reg_time ,count(user_id) dailyfrom user group by reg_time ) a ,(select @i:=0) b

查询的结果如下,符合逻辑需要。

reg_time

daily

daily_quantity

2019-09-03

1

1

2019-09-04

2

3

2019-09-05

2

5

2019-09-06

1

6

但是这里有一个小坑,在实际业务中`@i`初始化的时候有可能不为0,比如我们统计上面9月4号到9月6号这时候之前的总人数为1 。这个要特别注意。实际业务开发中如果我们能在逻辑编码中实现还是建议在逻辑编码中进行一些复杂的运算。

05、总结

今天我们通过mysql用户变量解决了一个在sql中累加计算的问题。不知道你有没有其它好的思路呢?欢迎留言讨论。

本文分享自微信公众号 - 码农小胖哥(Felordcn),作者:码农小胖哥

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2019-09-06

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Java 快速开发二维码生成服务

    不知道从什么时候开始,我们的生活突然之间就充满了二维码,连街边大妈的鸡蛋饼早餐摊也贴上了二维码。而且这次疫情的管控也用上了二维码,避免手工填写造成交叉感染。那么...

    码农小胖哥
  • Spring Boot 注入外部配置到应用内部的静态变量

    Spring Boot允许你外部化你的配置,这样你就可以在不同的环境中使用相同的应用程序代码,你可以使用properties文件、YAML文件、环境变量和命令行...

    码农小胖哥
  • Java面试通关要点汇总集之核心篇参考答案

    res = mysql_query( 'select * from order where date < = $curDate'); 原因: 释放了数据库的CP...

    码农小胖哥
  • AI招聘公司Moka再融1.8亿,90后学霸创始团队靠变革HR年入3000万

    比如,对于人类最基础的企业行为——招聘,AI也被创业公司Moka结合具体场景落地。

    量子位
  • Redis 数据结构和对象系统,有这 12 张图就够了!

    Redis 是一个开源的 key-value 存储系统,它使用六种底层数据结构构建了包含字符串对象、列表对象、哈希对象、集合对象和有序集合对象的对象系统。

    CSDN技术头条
  • 张龙netty学习笔记 P21-P23

    平凡的学生族
  • 关于hibernate中对象的三种状态分析

    一、首先Hibernate中对象的状态有三种:瞬态、游离态和持久态,三种状态转化的方法都是通过session来调用,瞬态到持久态的方法有save()、saveO...

    大黄大黄大黄
  • PhpStorm 2018 安装及方法 转

    PhpStorm 是 JetBrains 公司开发的一款商业的 PHP 集成开发工具。PhpStorm可随时帮助用户对其编码进行调整,运行单元测试或者提供可视化...

    双面人
  • 如何删除乱码文件

    birdskyws
  • 海尔正式发布COSMO平台,世界智能制造将要去哪?

    2月21日,就在2017工业互联网峰会上,海尔COSMO平台正式发布并对外提供社会化服务,这是中国首个也是最大的自主研发、自主创新的工业互联网平台,简单来说,它...

    曾响铃

扫码关注云+社区

领取腾讯云代金券