码迷,mamicode.com
首页 > 其他好文 > 详细

group by 用法

时间:2017-11-02 11:18:38      阅读:231      评论:0      收藏:0      [点我收藏+]

标签:入职   having   语句   工资   级别   汇总表   min   imu   返回   

group by(用来分组)语法可以根据给定数据列的每个成员对查询结果进行分组统计,最终得到一个分组汇总表

某个员工信息表结构和数据如下staff:
  id  name  dept  salary  edlevel  hiredate 
      1 张三 开发部 2000 3 2009-10-11
      2 李四 开发部 2500 3 2009-10-01
      3 王五 设计部 2600 5 2010-10-02
      4 王六 设计部 2300 4 2010-10-03
      5 马七 设计部 2100 4 2010-10-06
      6 赵八 销售部 3000 5 2010-10-05
      7 钱九 销售部 3100 7 2010-10-07
      8 孙十 销售部 3500 7 2010-10-06 

1、我想列出每个部门最高薪水的结果:

SELECT DEPT, MAX(SALARY) AS MAXIMUM
FROM STAFF
GROUP BY DEPT

“列函数对于GROUP BY子句定义的每个组各返回一个结果”,根据部门分组,对每个部门返回一个结果,就是每个部门的最高薪水。

2、查询公司2010年入职的各个部门每个级别里的最高薪水

SELECT DEPT, EDLEVEL, MAX( SALARY ) AS MAXIMUM
FROM staff
WHERE HIREDATE > ‘2010-01-01‘
GROUP BY DEPT, EDLEVEL
ORDER BY DEPT, EDLEVEL

3、寻找雇员平均工资大于3000的部门的最高和最低薪水:
SELECT DEPT, MAX( SALARY ) AS MAXIMUM, MIN( SALARY ) AS MINIMUM
FROM staff
GROUP BY DEPT
HAVING AVG( SALARY ) >3000
ORDER BY DEPT

 

注:WHERE语句在GROUP BY语句之前;SQL会在分组之前计算WHERE语句。   
  HAVING语句在GROUP BY语句之后;SQL会在分组之后计算HAVING语句。

 

group by 用法

标签:入职   having   语句   工资   级别   汇总表   min   imu   返回   

原文地址:http://www.cnblogs.com/lqbu/p/7770884.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!