登录
首页 >  数据库 >  MySQL

为什么我们不应该在 MySQL SELECT 查询中使用没有 GROUP BY 子句的非分组字段的分组函数?

来源:tutorialspoint

时间:2023-08-28 14:24:31 462浏览 收藏

数据库不知道大家是否熟悉?今天我将给大家介绍《为什么我们不应该在 MySQL SELECT 查询中使用没有 GROUP BY 子句的非分组字段的分组函数?》,这篇文章主要会讲到等等知识点,如果你在看完本篇文章后,有更好的建议或者发现哪里有问题,希望大家都能积极评论指出,谢谢!希望我们能一起加油进步!

这是因为如果没有 GROUP BY 子句,MySQL 返回的输出可能会产生误导。我们在下面给出的“学生”表中给出以下示例,以进行演示 -

mysql> Select * from Student;
+------+---------+---------+-----------+
| Id   | Name    | Address | Subject   |
+------+---------+---------+-----------+
| 1    | Gaurav  | Delhi   | Computers |
| 2    | Aarav   | Mumbai  | History   |
| 15   | Harshit | Delhi   | Commerce  |
| 20   | Gaurav  | Jaipur  | Computers |
+------+---------+---------+-----------+
4 rows in set (0.00 sec)

mysql> Select count(*), Name from Student;
+----------+--------+
| count(*) | name   |
+----------+--------+
| 4        | Gaurav |
+----------+--------+
1 row in set (0.00 sec)

从上面的查询结果中我们可以观察到,它返回组函数 COUNT(*) 的输出作为表中的总行数,但字段“Name”中的值“Gaurav”具有误导性,因为我们这样做根据什么基础,要么它是列的第一个值,要么它多次存储在列中,MySQL 返回它。

现在,如果我们使用 GROUP BY 子句编写此查询,则结果集如下如下 -

mysql> Select count(*), name from student GROUP BY id;
+----------+---------+
| count(*) | name    |
+----------+---------+
| 1        | Gaurav  |
| 1        | Aarav   |
| 1        | Harshit |
| 1        | Gaurav  |
+----------+---------+
4 rows in set (0.00 sec)

从上面的结果集中可以看出,在 GROUP BY 子句的帮助下,我们得到了有意义的输出。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《为什么我们不应该在 MySQL SELECT 查询中使用没有 GROUP BY 子句的非分组字段的分组函数?》文章吧,也可关注golang学习网公众号了解相关技术文章。

声明:本文转载于:tutorialspoint 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>