假设有一张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 子句中。”