mysql实现俩个属性加减运算_mysql累加计算实现方法详解

本文通过实例讲解了MySQL中使用用户变量进行累加计算的方法,以满足按时间维度统计每日总人数的需求。通过设置初始值并逐条累加,得出每日累计总人数,同时提醒在实际业务中需要注意变量初始化的特殊情况。
摘要由CSDN通过智能技术生成

本文实例讲述了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如下:

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代码处理这个就再合适不过了,我们只要声明初始值,然后循环累加就能计算出结果了:

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_id

from user_info ,(select @i:=0) as r

Mysql 用户变量

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

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

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

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

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相关内容感兴趣的读者可查看本站专题:《MySQL查询技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》、《MySQL数据库锁相关技巧汇总》及《MySQL常用函数大汇总》

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

本文标题: mysql累加计算实现方法详解

本文地址: http://www.cppcns.com/shujuku/mysql/313856.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值