首先:有一个employees表,长这样
group by
group by + 列名,意思就是通过列名来将查询到的信息经进行分组
不如说:上面表中,John和Mike在同一个department(部门)中,如果将查询到的结果用group by department分组,那么John所在列和Mike所在列就会在同一组,因为John和Mike的department相同
举个例子:
如果不分组
,直接查询salary(工资)的平均值,求出的是所有的salary的平均值,结果只有一条记录 ,如果我想计算不同department(部门)的平均工资,要怎么操作呢?
就需要通过group by来分组,这样就将不同department的平均工资算出来了
也可以多次分组,如下:将avg(salary)先通过department分组,也就是相同department的行被分到一组,再通过job再分组,就是将同一个department下如果有相同的job就分到一组,如下表:Sales部门中,有两个不同的job,checker和cleaner,所以有两条信息;
having
having的作用就是条件筛选,比如在上面的语句中,我只想查询平均工资大于5000的,就可以用having进行条件筛选,having avg(salary)> 5000