mysql累加计算实现方法详解_Mysql

来源:脚本之家  责任编辑:小易  

mysql>delimiter|mysql>create procedure p1(OUT vout intbegindeclare v1 int default 1;declare v2 int default 0;while v1set v2=v2+v1;set v1=v1+1;end while;SET vout=v2;end;Query OK,0 rows affected(0.00 sec)mysql>call p1(@count);Query OK,0 rows affected(0.00 sec)mysql>select@count|count|5050|1 row in set(0.00 sec)mysql>delimiter;mysql>_mysql>delimiter|mysql>create procedure p2(OUT vout int)begindeclare v1 int default 1;declare v2 int default 0;while v1IF v1 MOD 2=0 THENset v2=v2+v1;END IF;set v1=v1+1;end while;SET vout=v2;end;Query OK,0 rows affected(0.00 sec)mysql>call p2(@a);Query OK,0 rows affected(0.00 sec)mysql>select@a|a|2550|1 row in set(0.00 sec)mysql>mysql>create procedure p3(OUT vout int)begindeclare v1 int default 1;declare v2 int default 0;while v1IF v1 MOD 2=1 THENset v2=v2+v1;END IF;set v1=v1+1;end while;SET vout=v2;end;Query OK,0 rows affected(0.00 sec)mysql>call p3(@A)|Query OK,0 rows affected(0.00 sec)mysql>select@A|A|2500|1 row in set(0.00 sec)mysql>www.zgxue.com防采集请勿采集本网。

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

前言

SELECT SUM(field_name)FROM tblName WHERE UNIX_TIMESTAMP(month)(CURRENT_DATE(),INTERVAL-1 MONTH)GROUP BY month;

接了一个需求,产品想分析一下用户增长的曲线。也就是某个时间段的每日总人数列表。好对近期活动进行一个效果的评测。这个统计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

如果你year和month是字符型的话用这个,把表名换一下,我起的叫test(一共两处) select b.year,b.month,sum(a.membercount) from test a,test b where format(a.year+'-'+a.month+'-01')(b.year

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

换其他数据库一个 sum()over(partition by.)就解决了. mysql比较麻烦,可以试下 select a.Daytime,sum(new_Role) from(select distinct DATE_FORMAT(createtime,'%Y-%m-%d')as Daytime) from `actors`

select reg_time, count(user_id) daily_quantity from user_infogroup by reg_time

啊,这个,用求和函数SUM就可以了 用迭代计算

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

reg_time daily_quantity
2019-09-03 1
2019-09-04 2
2019-09-05 2
2019-09-06 1

求和很简单呀,套一层sql语句就可以了,中间是你的sql语句,取出来的字段最好起个别名(这里用val),临时的那个结果也给起个别名(这里用t): select sum(t.val)from select count(distinct

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

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数据库计有所帮助。

由于我是在window环境下运行,我把FROM_UNIXTIME去掉,才能运行。selecttablename_tmp.*pstatus:=concat(CONCAT(@pstatus,'+'),@ptempstatus)as countstatuspstatus:=concat(@pstatus,@ptempstatus)as prevstatusptempstatus:=concat('+',COUNT)fromselect DATE_FORMAT(FROM_UNIXTIME(order_time),'%Y-%m-%d')as TIME,COUNT(*)AS COUNT from user_order group by timetablename_tmp(select@pstatus:='',@ptempstatus:='1')a内容来自www.zgxue.com请勿采集。


  • 本文相关:
  • mysql计算时间差函数
  • mysql中通过生日计算年龄的多种方法
  • 在php和mysql中计算时间差的方法
  • mysql 字符串长度计算实现代码(gb2312+utf8)
  • mysql数据库的qps和tps的意义和计算方法
  • mysql几点重要的性能指标计算和优化方法总结
  • 浅谈mysql explain中key_len的计算方法
  • mysql的查询计划中ken_len的值计算方法
  • mysql日期和时间的间隔计算实例分析
  • mysql日期加减函数详解
  • mysql 触发器创建与使用方法示例
  • mysql触发器基本用法详解【创建、查看、删除等】
  • 用eclipse连接mysql数据库的步骤
  • sql和mysql的语句执行顺序分析
  • 解决mysql客户端输出窗口显示中文乱码问题的办法
  • mysql大小写敏感的问题
  • mysql性能监控工具innotop简介及配置
  • 实例解析mysql中的存储过程及存储过程的调用方法
  • windows10下安装解压版mysql教程图文详解
  • 图解mysql数据库的安装
  • mysql5.6忘记root密码修改root密码的方法
  • 详解mysql数据库设置主从同步的方法
  • mysql 计算累加值
  • MYSQL用存储过程求1到100累加
  • SQL中计算字段的累加和的函数是?统计项目数的函数是?有谁知道吗?
  • 计算器累加怎么用?
  • mysql数据库实现月度累加统计:5月统计5,4,3..之前月的。并分组统计。
  • 关于SQL计算累加
  • MYSQL求每天的总和累加
  • 如何实现EXCEL中的累加计算
  • mysql中,先分组,按某个字段计数,然后把计算出的数求和,怎么写,
  • c语言计算1+2+……+n的累加求和 用while和for俩种方法?
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全mssqlmysqlmariadboracledb2mssql2008mssql2005sqlitepostgresqlmongodbredisaccess数据库文摘数据库其它首页mysqlmysql查询技巧大全mysql事务操作技巧汇总mysql存储过程技巧大全mysql数据库锁相关技巧汇总mysql常用函数大汇总mysql计算时间差函数mysql中通过生日计算年龄的多种方法在php和mysql中计算时间差的方法mysql 字符串长度计算实现代码(gb2312+utf8)mysql数据库的qps和tps的意义和计算方法mysql几点重要的性能指标计算和优化方法总结浅谈mysql explain中key_len的计算方法mysql的查询计划中ken_len的值计算方法mysql日期和时间的间隔计算实例分析mysql日期加减函数详解mysql 触发器创建与使用方法示例mysql触发器基本用法详解【创建、查看、删除等】用eclipse连接mysql数据库的步骤sql和mysql的语句执行顺序分析解决mysql客户端输出窗口显示中文乱码问题的办法mysql大小写敏感的问题mysql性能监控工具innotop简介及配置实例解析mysql中的存储过程及存储过程的调用方法windows10下安装解压版mysql教程图文详解图解mysql数据库的安装mysql5.6忘记root密码修改root密码的方法详解mysql数据库设置主从同步的方法mysql安装图解 mysql图文安装教程can""""t connect to mysql servwindows下mysql5.6版本安装及配置mysql字符串截取函数substring的mysql创建用户与授权方法mysql提示:the server quit withmysql——修改root密码的4种方法mysql日期数据类型、时间类型使用mysql update语句的用法详解mysql 的case when 语句使用说明简单实现mysql服务器的优化配置方法linux下二进制方式安装mysql5.7版本和系统mysql数值类型溢出的处理方法详解mysql中drop,truncate 和delete的区别win10免安装版本的mysql安装配置教程phpmyadmin 配置文件现在需要一个短语密码centos6.5下rpm方式安装mysql5.6.33的详细mysql字符集乱码问题解决方法介绍mysql php语法浅析mysql导入导出数据中文乱码解决方法小结
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved