黑马程序员技术交流社区

标题: SQL中group by 语句的含义和详细用法 [打印本页]

作者: 王兴    时间: 2012-1-1 00:47
标题: SQL中group by 语句的含义和详细用法
本帖最后由 王兴 于 2012-1-1 18:39 编辑

书上说group by可以将一个表分割成逻辑组,并对每一组计算聚合统计量。。可是没有看明白是什么意思,能不能举个例子
作者: 傅涌钦    时间: 2012-1-1 09:39
本帖最后由 傅涌钦 于 2012-1-1 10:10 编辑

假设有一张T_Person表
表有这几个属性:ID, Name,Age,Salary
然后我们要检索个年龄段(按年龄分组)以及对应的最高工资(聚集函数作用于每个分组):
select Age as 年龄  , max(Salary)  as  最大工资 from T_Person group by Age

比如 :
ID   Name   Age   Salary
1   steven    19    5362
2   wifi          19    5620
3   amy        21    5320
4   bin          23    5000
5   fin           22    5600
6   okn         23    6520

output:
  年龄    最大工资

19       5620

21      5320

22      5600

23      6520

注意:如果未对查询分组,聚集函数将作用于整个查询结果!也就只检索到最大的6520
作者: 独孤飞雪    时间: 2012-1-1 13:37
select * from T_table group by gender 就是说按照性别分组显示所有信息。
作者: 朱磊    时间: 2012-1-1 14:15
Group By 的字面意思就是:通过...来分组,楼上已经给出实际的例子了,只需要实践一下,能够理解就OK了。
作者: 傅涌钦    时间: 2012-1-1 14:23
独孤飞雪 发表于 2012-1-1 13:37
select * from T_table group by gender 就是说按照性别分组显示所有信息。

“选择列表中的列 'person.ID' 无效,因为该列没有包含在聚合函数或 GROUP BY 子句中。”

你那样写SQL你的MS SQL Server数据库不会报上面对错误!??
作者: 独孤飞雪    时间: 2012-1-1 14:33
有设置主键么?

作者: 独孤飞雪    时间: 2012-1-1 14:41
奥,不好意思,不能用*,忘了。。。
作者: 傅涌钦    时间: 2012-1-1 16:12
独孤飞雪 发表于 2012-1-1 14:41
奥,不好意思,不能用*,忘了。。。

呵呵,没事,刚好看到,问问:handshake
作者: 王兴    时间: 2012-1-1 18:38
貌似有点懂了,谢谢大家的解答




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2