服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|

服务器之家 - 数据库 - Mysql - mysql累加计算实现方法详解

mysql累加计算实现方法详解

2021-01-19 18:05码农小胖哥 Mysql

这篇文章主要介绍了mysql累加计算实现方法,结合实例形势分析了mysql累加计算原理、实现方法及操作注意事项,需要的朋友可以参考下

本文实例讲述了mysql累加计算。分享给大家供大家参考,具体如下:

 

前言

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

 

需求分析

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如下:

?
1
2
3
select reg_time, count(user_id) daily_quantity
 from user_info
group 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代码处理这个就再合适不过了,我们只要声明初始值,然后循环累加就能计算出结果了:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
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表举例子:

?
1
2
select (@i:=@i+1) as rownum, user_id
 from user_info ,(select @i:=0) as r

 

Mysql 用户变量

mysql 变量分为 局部变量、用户变量、会话变量、全局变量 。上面的语句我们使用的是用户变量。用户变量与数据库连接有关,在连接中声明的变量,在存储过程中创建了用户变量后一直到数据库实例接断开的时候,变量就会消失。在此连接中声明的变量无法在另一连接中使用。
MySQL中用户变量不用事前申明,使用的时候以@varname的格式进行声明。通过:=或者=进行赋值操作。如果需要对外输出需要用select关键字,而且赋值必须使用:=

 

使用Mysql用户变量进行累加计算

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

?
1
2
3
4
5
6
7
select a.reg_time,
   a.daily,
  @i:=@i+a.daily as daily_quantity
 from (select reg_time , 
 count(user_id) daily
 from 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 。 这个要特别注意。实际业务开发中如果我们能在逻辑编码中实现还是建议在逻辑编码中进行一些复杂的运算。

 

总结

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

希望本文所述对大家MySQL数据库计有所帮助。

原文链接:https://segmentfault.com/a/1190000020310031

延伸 · 阅读

精彩推荐
  • MysqlNavicat查询结果不能修改的原因及解决方法

    Navicat查询结果不能修改的原因及解决方法

    下面小编就为大家带来一篇Navicat查询结果不能修改的原因及解决方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看...

    数据库之家7992020-07-05
  • Mysqlmysql中Table is read only的解决方法小结

    mysql中Table is read only的解决方法小结

    本文章总结了关于在linux与windows中 mysql出现Table is read only解决办法总结,有需要的朋友可参考一下 ...

    MYSQL教程网2642019-12-16
  • Mysql数据库 MySQL中文乱码解决办法总结

    数据库 MySQL中文乱码解决办法总结

    这篇文章主要介绍了数据库 MySQL中文乱码解决办法总结的相关资料,数据库保存中文字符,所以经常遇到数据库乱码情况,这里提供了几种方法,需要的朋友...

    carl-zhao2722020-05-18
  • Mysql解析mysql与Oracle update的区别

    解析mysql与Oracle update的区别

    本篇文章是对mysql与Oracle update的区别进行了详细的分析介绍,需要的朋友参考下 ...

    MYSQL教程网1622020-01-06
  • MysqlCentOS6.9下mysql 5.7.17安装配置方法图文教程

    CentOS6.9下mysql 5.7.17安装配置方法图文教程

    这篇文章主要为大家详细介绍了CentOS6.9下mysql 5.7.17安装配置方法图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    那山的狐狸5022020-08-18
  • Mysqlmysql命令行下用户管理方法分享

    mysql命令行下用户管理方法分享

    如果有mysql管理工具phpmyadmin的话,我们可以通过图形画界面来对用户进行管理,但是如果没有phpmyadmin这样的管理工具怎么办呢 ...

    海底苍鹰4882019-12-04
  • Mysqlmysql中的一些稍微复杂用法实例代码

    mysql中的一些稍微复杂用法实例代码

    这篇文章主要给大家介绍了关于mysql中的一些稍微复杂用法的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用mysql具有一定的参考学习价...

    gaoziyuecj3522019-06-18
  • Mysql从零开始学习SQL查询语句执行顺序

    从零开始学习SQL查询语句执行顺序

    sql语言中的查询的执行顺序,以前不是很了解,最近查阅了相关资料,在sql语言中,第一个被处理的字句总是from字句,最后执行的limit操作,现在小编来和...

    alwayssmile213762020-09-27