SQL中group by语句有何作用?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL中group by语句有何作用?相关的知识,希望对你有一定的参考价值。

是用来分组的。
比如A表里面有数据如下
字段1
字段2
字段3
A
A1
A2
B
B1
B2
A
A2
A3
A
A4
A1
我想查出这表里面到底有几个人
那么就要用到group
by来进行分组
select
字段1
from
A
group
by
字段1
那么结果是
字段1
A
B
这2条数据
参考技术A 分类汇总的时候用。group
by
:表示按字段分组。例如:分别计算男性用户和女性用户的平均年龄。select
性别,avg(年龄)
as
average
from
表名
group
by
性别
参考技术B group
by
一般跟聚合函数(sum,max,min,avg,count)同时使用。
当使用者几个函数时,若不使用group
by
进行分组,则对所有记录进行聚合函数计算,若使用group
by
进行分组,则对每组进行计算。
比如这样个表tmp:
类型

A
8
B
6
A
9
B
4
如果
select
max(值)from
tmp
则返回一个值
9
但要是
select
max(值)from
tmp
group
by
类型
则返回两个值
9
6

SQL中GROUP BY语句与HAVING语句的使用

一、GROUP BY

GROUP BY语句用来与聚合函数(aggregate functions such as COUNT, SUM, AVG, MIN, or MAX.)联合使用来得到一个或多个列的结果集。

语法如下:

SELECT column1, column2, ... column_n, aggregate_function (expression)            

FROM tables            

WHERE predicates            

GROUP BY column1, column2, ... column_n;

 

举例

比如说我们有一个学生表格(student),包含学号(id),课程(course),分数(score)等等多个列,我们想通过查询得到每个学生选了几门课程,此时我们就可以联合使用COUNT函数与GROUP BY语句来得到这一结果

SELECT id, COUNT(course) as numcourse

FROM student

GROUP BY id

因为我们是使用学号来进行分组的,这样COUNT函数就是在以学号分组的前提下来实现的,通过COUNT(course)就可以计算每一个学号对应的课程数。

 

注意

因为聚合函数通过作用于一组数据而只返回一个单个值,因此,在SELECT语句中出现的元素要么为一个聚合函数的输入值,要么为GROUP BY语句的参数,否则会出错。

例如,对于上面提到的表格,我们做一个这样的查询:

SELECT id, COUNT(course) as numcourse, score

FROM student

GROUP BY id

此时查询便会出错,错误提示如下:

Column ‘student.score‘ is invalid in the select list because it is not contained in either an aggregate function or the GROUP BY clause.

出现以上错误的原因是因为一个学生id对应多个分数,如果我们简单的在SELECT语句中写上score,则无法判断应该输出哪一个分数。如果想用score作为select语句的参数可以将它用作一个聚合函数的输入值,如下例,我们可以得到每个学生所选的课程门数以及每个学生的平均分数:

SELECT id, COUNT(course) as numcourse, AVG(score) as avgscore

FROM student

GROUP BY id

 

二、HAVING

HAVING语句通常与GROUP BY语句联合使用,用来过滤由GROUP BY语句返回的记录集。

HAVING语句的存在弥补了WHERE关键字不能与聚合函数联合使用的不足。

语法:

SELECT column1, column2, ... column_n, aggregate_function (expression)
FROM tables
WHERE predicates
GROUP BY column1, column2, ... column_n
HAVING condition1 ... condition_n;

同样使用本文中的学生表格,如果想查询平均分高于80分的学生记录可以这样写:

SELECT id, COUNT(course) as numcourse, AVG(score) as avgscore

FROM student

GROUP BY id

HAVING AVG(score)>=80;

在这里,如果用WHERE代替HAVING就会出错。





以上是关于SQL中group by语句有何作用?的主要内容,如果未能解决你的问题,请参考以下文章

sql group by用法

SQL语句中的Group by的学习

SQL语句:Group By总结

group by后接的having语句怎样使用才是有效的,我为啥不行的

group by...having count()的问题

group by与distinct有何区别