本文实例讲述了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如下:
selectreg_time,count(user_id)daily_quantity fromuser_info groupbyreg_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代码处理这个就再合适不过了,我们只要声明初始值,然后循环累加就能计算出结果了:
publicstaticvoidmain(String[]args){ int[]arr={1,2,2,1}; int[]ints=dailyQuantityArr(0,arr); for(inti:ints){ System.out.println("i="+i); } } publicstaticint[]dailyQuantityArr(intbase,int[]dailyIncrQuantity){ int[]result=newint[dailyIncrQuantity.length]; //累加填充 for(inti=0;i<dailyIncrQuantity.length;i++){ base+=dailyIncrQuantity[i]; result[i]=base; } returnresult; }
上面的伪代码就可以计算出结果。当然如果可以的话尽量在java业务代码进行这种复杂运算。但是产品给出的需求是我们能够提供一句sql能够直接在可视化数据引擎中得出他要的答案。于是从上面的代码得出灵感。
mysql是否有这种变量呢?有!当然有。记得很普遍的场景,以前经常有业务需要我们输出序号,Oracle是自带一个伪列rownum,但是mysql没有。mysql通常通过声明自增变量来生成序号。拿user_info表举例子:
select(@i:=@i+1)asrownum,user_id fromuser_info,(select@i:=0)asr
Mysql用户变量
mysql变量分为局部变量、用户变量、会话变量、全局变量。上面的语句我们使用的是用户变量。用户变量与数据库连接有关,在连接中声明的变量,在存储过程中创建了用户变量后一直到数据库实例接断开的时候,变量就会消失。在此连接中声明的变量无法在另一连接中使用。
MySQL中用户变量不用事前申明,使用的时候以@varname的格式进行声明。通过:=
或者=
进行赋值操作。如果需要对外输出需要用select
关键字,而且赋值必须使用:=
。
使用Mysql用户变量进行累加计算
我们学习了用户变量后就知道如何进行累加计算了,那么user_info表的日累计总人数应该是这样的:
selecta.reg_time, a.daily, @i:=@i+a.dailyasdaily_quantity from(selectreg_time, count(user_id)daily fromusergroupbyreg_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累加计算实现方法详解分享的全部内容,如果对大家有所用处且需要了解更多关于mysql数据库学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!
本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。
ctvol管理联系方式QQ:251552304
本文章地址:https://www.ctvol.com/dtteaching/909308.html