MySQL数据分组Group By 和 Having

现有以下的学生信息表:

若果现在想计算每个班的平均年龄,使用where的操作如下:

SELECT Cno AS 班级, AVG(Sage) AS 平均年龄
FROM stu
Where Cno=5;

这样的话,有多少个班就需要操作几次

因此引入分组 GROUP BY子句,根据列来分组,先看一下《MySQL必知必会》的提示:

引入分组后,操作如下:

SELECT Cno AS 班级,AVG(Sage) AS 平均年龄 FROM stu GROUP BY Cno;

由此可以理解,GROUP BY 根据给出的列进行分组,具有相同列属性的被分到一组,然后你需要对组内的数据执行什么操作,就和平常的一样,只是操作的不再是所有的数据,而是分组后的。

猜你喜欢

转载自www.cnblogs.com/Guhongying/p/10545962.html