在 MySQL SELECT 查询中,我们为什么不应在没有 GROUP BY 子句的情况下将组函数与非组字段一起使用?


这是因为如果没有 GROUP BY 子句,MySQL 返回的输出可能会产生误导。我们提供以下示例,对下面给出的“Student”表进行了演示:−

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 子句,我们获得了有意义的输出。

更新于: 30-01-2020

186 次浏览

开启你的 职业生涯

通过完成课程获得认证

开始
广告