order by 与group by 数据库高手看看
1个回答

1,

2,

3,

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 ] ]