mysql如何进行累加计算
来源:SegmentFault
时间:2023-01-12 13:30:27 240浏览 收藏
本篇文章向大家介绍《mysql如何进行累加计算》,主要包括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
上面的伪代码就可以计算出结果。当然如果可以的话尽量在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 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的内容请关注golang学习网公众号!
-
499 收藏
-
244 收藏
-
235 收藏
-
157 收藏
-
101 收藏
-
121 收藏
-
107 收藏
-
278 收藏
-
231 收藏
-
120 收藏
-
393 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习
-
- 结实的鱼
- 这篇文章出现的刚刚好,很详细,写的不错,已加入收藏夹了,关注楼主了!希望楼主能多写数据库相关的文章。
- 2023-05-19 00:21:51
-
- 爱笑的朋友
- 写的不错,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢作者大大分享技术文章!
- 2023-05-16 08:28:41
-
- 落寞的月亮
- 很好,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢楼主分享技术贴!
- 2023-02-13 17:15:48
-
- 炙热的河马
- 这篇文章内容太及时了,很详细,感谢大佬分享,已加入收藏夹了,关注博主了!希望博主能多写数据库相关的文章。
- 2023-01-22 02:35:56
-
- 满意的老师
- 这篇技术文章太及时了,太全面了,受益颇多,码起来,关注作者大大了!希望作者大大能多写数据库相关的文章。
- 2023-01-16 01:37:35
-
- 丰富的曲奇
- 写的不错,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢楼主分享技术文章!
- 2023-01-13 08:40:27