日期:2014-05-16 浏览次数:20424 次
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 真对使用了聚合函数的字段进行分组归类,有一定的局限性 ? ?
?