日期:2014-05-16  浏览次数:20396 次

order by 和 group by 的区别

sql 里的 order by group by 的区别:

?

order by 从英文里理解就是行的排序方式,默认的为升序。 order by 后面必须列出排序的字段名,可以是多个字段名。

?

group by 从英文里理解就是分组。必须有聚合函数来配合才能使用,使用时至少需要一个分组标志字段。

?

?什么是聚合函数

?

??? 像sum()count()avg()等都是聚合函数

?

??? 使用group by 的目的就是要将数据分类汇总。

?

一般如:

?

select 单位名称,count(职工id),sum(职工工资) form [某表] group by 单位名称

?

这样的运行结果就是以单位名称为分类标志统计各单位的职工人数和工资总额。

?

sql命令格式使用的先后顺序上,group by 先于 order by

?

select 命令的标准格式如下:

?

?SELECT select_list???

?

[ INTO new_table ]???

?

FROM table_source???

?

[ WHERE search_condition ]???

?

[ GROUP BY group_by_expression ]???

?

[ HAVING search_condition ]???

?

[ ORDER BY order_expression [ ASC | DESC ] ]

?

order by 是按字段排序

?

group by 是按字段分类

?

select deptno,sum(sal) from emp where sal>1200 group by deptno having sum(sal)>8500 order by deptno;

当在gropu by 子句中使用having 子句时,查询结果中只返回满足having条件的组。在一个sql语句中可以有where子句和having子句。having 与where 子句类似,均用于设置限定条件

?

备注:

?

我认为,order by 和 group by 都有按给定的字段归类的意思,只是使用聚合函数时要用group by 真对使用了聚合函数的字段进行分组归类,有一定的局限性

?

?

?