全国旗舰校区

不同学习城市 同样授课品质

北京

深圳

上海

广州

郑州

大连

武汉

成都

西安

杭州

青岛

重庆

长沙

哈尔滨

南京

太原

沈阳

合肥

贵阳

济南

下一个校区
就在你家门口
+
当前位置:首页  >  技术干货

Mysql中sum和group by联用求和为什么会计算不准确?

发布时间:2023-10-13 14:19:18
发布人:xqq

一、Mysql中sum和group by联用求和为什么会计算不准确

因为在MySQL中,GROUP BY 语句根据一个或多个列对结果集进行分组。在分组的列上我们可以使用 COUNT, SUM, AVG,等函数。WITH ROLLUP 可以实现在分组统计数据基础上再进行相同的统计(SUM,AVG,COUNT…)。

GROUP BY 语法

SELECT column_name, function(column_name)

FROM table_name

WHERE column_name operator value

GROUP BY column_name;

实例演示

本章节实例使用到了以下表结构及数据,使用前我们可以先将以下数据导入数据库中。

SET NAMES utf8;

SET FOREIGN_KEY_CHECKS = 0;

— —————————-

—  Table structure for employee_tbl

— —————————-

DROP TABLE IF EXISTS employee_tbl;

CREATE TABLE employee_tbl (

  id int(11) NOT NULL,

  name char(10) NOT NULL DEFAULT ”,

  date datetime NOT NULL,

  signin tinyint(4) NOT NULL DEFAULT ‘0’ COMMENT ‘登录次数’,

  PRIMARY KEY (id)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

— —————————-

—  Records of employee_tbl

— —————————-

BEGIN;

INSERT INTO employee_tbl VALUES (‘1’, ‘小明’, ‘2016-04-22 15:25:33’, ‘1’), (‘2’, ‘小王’, ‘2016-04-20 15:25:47’, ‘3’), (‘3’, ‘小丽’, ‘2016-04-19 15:26:02’, ‘2’), (‘4’, ‘小王’, ‘2016-04-07 15:26:14’, ‘4’), (‘5’, ‘小明’, ‘2016-04-11 15:26:40’, ‘4’), (‘6’, ‘小明’, ‘2016-04-04 15:26:54’, ‘2’);

COMMIT;

SET FOREIGN_KEY_CHECKS = 1;

导入成功后,执行以下 SQL 语句:

mysql> set names utf8;

mysql> SELECT * FROM employee_tbl;

+—-+——–+———————+——–+

| id | name   | date                | signin |

+—-+——–+———————+——–+

|  1 | 小明 | 2016-04-22 15:25:33 |      1 |

|  2 | 小王 | 2016-04-20 15:25:47 |      3 |

|  3 | 小丽 | 2016-04-19 15:26:02 |      2 |

|  4 | 小王 | 2016-04-07 15:26:14 |      4 |

|  5 | 小明 | 2016-04-11 15:26:40 |      4 |

|  6 | 小明 | 2016-04-04 15:26:54 |      2 |

+—-+——–+———————+——–+

6 rows in set (0.00 sec)

接下来我们使用 GROUP BY 语句 将数据表按名字进行分组,并统计每个人有多少条记录:

mysql> SELECT name, COUNT(*) FROM   employee_tbl GROUP BY name;

+——–+———-+

| name   | COUNT(*) |

+——–+———-+

| 小丽 |        1 |

| 小明 |        3 |

| 小王 |        2 |

+——–+———-+

3 rows in set (0.01 sec)

WITH ROLLUP 可以实现在分组统计数据基础上再进行相同的统计(SUM,AVG,COUNT…),使用 WITH ROLLUP,此函数是对聚合函数进行求和,注意 with rollup是对 group by 后的名列前茅个字段,进行分组求和。

延伸阅读:

二、数据库和 SQL 概念

数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,它的产生距今已有六十多年。随着信息技术和市场的发展,数据库变得无处不在:它在电子商务、银行系统等众多领域都被广泛使用,且成为其系统的重要组成部分。

数据库用于记录数据,使用数据库记录数据可以表现出各种数据间的联系,也可以很方便地对所记录的数据进行增、删、改、查等操作。

结构化查询语言(Structured Query Language)简称 SQL,是上世纪 70 年代由 IBM 公司开发,用于对数据库进行操作的语言。更详细地说,SQL 是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统,同时也是数据库脚本文件的扩展名。

#it技术干货

相关文章

jdbc的resultset底层实现原理是怎样的?

jdbc的resultset底层实现原理是怎样的?

2023-10-13
两个后台应用(J2EE)操作同一个数据库有什么风险?

两个后台应用(J2EE)操作同一个数据库有什么风险?

2023-10-13
做网站要保存很多商家和商品图片,原理是怎样的?

做网站要保存很多商家和商品图片,原理是怎样的?

2023-10-13
为什么要把几种完全不同的东西统称为NoSQL?

为什么要把几种完全不同的东西统称为NoSQL?

2023-10-13

最新文章

常见网络安全面试题:Windows常用的命令有哪些?

常见网络安全面试题:Windows常用的命令有哪些?

2023-10-09
常见网络安全面试题:根据设备告警如何展开排查?

常见网络安全面试题:根据设备告警如何展开排查?

2023-10-09
常见网络安全面试题:mysql加固呢?(数据库加固)

常见网络安全面试题:mysql加固呢?(数据库加固)

2023-10-09
常见网络安全面试题:windows和linux加固?(操作系统加固)

常见网络安全面试题:windows和linux加固?(操作系统加固)

2023-10-09
在线咨询 免费试学 教程领取