A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 王兴 黑马帝   /  2012-1-1 00:47  /  3158 人查看  /  8 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 王兴 于 2012-1-1 18:39 编辑

书上说group by可以将一个表分割成逻辑组,并对每一组计算聚合统计量。。可是没有看明白是什么意思,能不能举个例子

评分

参与人数 1技术分 +2 收起 理由
李荣壮 + 2

查看全部评分

8 个回复

倒序浏览
本帖最后由 傅涌钦 于 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

评分

参与人数 1技术分 +2 收起 理由
李荣壮 + 2

查看全部评分

回复 使用道具 举报
select * from T_table group by gender 就是说按照性别分组显示所有信息。
回复 使用道具 举报
Group By 的字面意思就是:通过...来分组,楼上已经给出实际的例子了,只需要实践一下,能够理解就OK了。
回复 使用道具 举报
独孤飞雪 发表于 2012-1-1 13:37
select * from T_table group by gender 就是说按照性别分组显示所有信息。

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

你那样写SQL你的MS SQL Server数据库不会报上面对错误!??
回复 使用道具 举报
有设置主键么?
回复 使用道具 举报
奥,不好意思,不能用*,忘了。。。
回复 使用道具 举报
独孤飞雪 发表于 2012-1-1 14:41
奥,不好意思,不能用*,忘了。。。

呵呵,没事,刚好看到,问问:handshake
回复 使用道具 举报
王兴 黑马帝 2012-1-1 18:38:16
9#
貌似有点懂了,谢谢大家的解答
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马