`
simple_hui
  • 浏览: 153162 次
  • 性别: Icon_minigender_2
  • 来自: 武汉
社区版块
存档分类
最新评论

group by 与 order by

SQL 
阅读更多
例如现在有这样的表test
id    name    age
1     aaa     20
2     bbb     25
3     ccc     20
4     ddd     25
select * from test group by 出来的结果是
id    name  
1     aaa    20
2     bbb    25

那么
select * from test group by age order by id 是否会是
id    name   age
4     ddd    25
3     ccc    20
还是
id    name   age
2     bbb    25
1     aaa    20
答案:
id    name   age
2     bbb    25
1     aaa    20

即order by 是在group by之后执行的


select max(id), age from test group by
id   age
3    20
4    25

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

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics