首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SQL学习之分组数据Group by

SQL学习之分组数据Group by

作者头像
郑小超.
发布2018-01-24 15:22:32
1.2K0
发布2018-01-24 15:22:32
举报
文章被收录于专栏:GreenLeavesGreenLeaves

简介:"Group By"根据字面上的意思理解,就是根据"By"后面指定的规则对数据进行分组(分组就是将一个数据集按照"By"指定的规则分成若干个子数据集),然后再对子数据集进行数据处理。

1、下面通过一个实例来了解"Group By"的作用和功能,代码如下:

select * from course

这是一个课程明细表,现在有一个报表程序,需要每个老师的编号,以及每位老师所教的课程总数,下面是解决代码:

select tno,COUNT(cname) as courses from course group by tno
image.png
image.png

这就是个人的理解,上图是通过Group By分组之后的第一组,后面的数据集合包含教师ID为t001的所有行数数据,这个数据集合我们可以使用聚集函数来获取我们想要的信息,但是无法获取其中的详细的列信息!原因我们可以通过上图的结构可以看出!

ok,通过group by 完成需求!

上面的Select指定了两个列,tno包含教师的编号,courses 为计算字段(用Count()函数建立),group by子句指示DBMS按tno排序并分组数据。这就会对每个tno而不是整个表计算courses一次(也就是说DBMS会对(按照tno排序并分组之后的单个数据子集)进行Count()运算,而不是真个数据集)。

2、下面是使用Group By子句需要知道的一些重要的规定

(1)Group By子句可以包含任意数目的列,因而可以对分组进行嵌套,进行更细致的分组。

(2)Group By子句中列出的每一列都必须是检索列(或者有效的表达式,注意不能是聚集函数)。如果在SELECT中使用了检索列(或者表达式),则在Group By子句中使用相同的表达式,不能使用别名。

(3)大多数SQL不允许Group By带有可变长度的数据类型(如文本,text类型)。

(4)除聚集计算语句外,SELECT语句中的每一列都必须在Group By中给出。

(5)如果分组列中包含具有Null值的行,则Null将作为一个分组返回,如果列中有多行Null,他们将作为一个分组返回。

(6)Group By必须出现在Where子句之后,Order By子句之前。

(7)如果在Group By子句中嵌套了分组,数据将在最后指定的分组上进行汇总。换句话说,在建立分组时,指定的所有列都一起计算(不能从个别的列中取回数据)。

3、Group By All+多个字段,Group By+多个字段

在SQL Server 中Group By All+多个字段和Group By+多个字段在效果是一样的,都是通过多个字段来分组!如下代码:

select * from course

这是一个课程明细表,现在有个报表程序需要展示每个老师教授的课程(相同的课程)一共教多少个班级,下面是解决代码:

select tno,cname,COUNT(cname) from course group by all tno,cname order by tno

这是个人的理解,上图是通过Group By分组之后的第一组,后面的数据集合包含(教师ID为t001并且课程名称为Oracle)的所有行数数据,这个数据集合我们可以使用聚集函数来获取我们想要的信息,但是无法获取其中的详细的列信息!原因我们可以通过上图的结构可以看出!

ok,解决需求,通过上面的结果图,我们可以看出,三个老师所教的课程基本都只教一个班,除了t003老师的sql SERVER 2005教了两个班,当然我们实际的业务中,并不会这样建表,我这边指示为了演示Group By+多个字段能完成的功能,才强行构建这个需求!

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016-08-28 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档