码迷,mamicode.com
首页 > 数据库 > 详细

oracle数据库GROUP BY 子句

时间:2019-10-29 09:28:14      阅读:84      评论:0      收藏:0      [点我收藏+]

标签:包含   where   查询   使用   过滤   数据   第一个   avg   rom   

1.GROUP BY子句

在SELECT 列表中所有未包含在组函数中的列都应该包含在GROUP BY 子句中.

如下:

SELECT deptno,AVG(sal) from emp GROUP BY deptno;(deptno为没有包含在组函数的列)

以下查询是错误的:

SELECT a,b,c,AVG(sal) from emp GROUP BY a,b;(c没有写在group by 后面)

===========================================================================================

多个列的分组:先按照第一个列分组,如果相同,再第二个列分组,以此类推

===========================================================================================

2.过滤分组:HAVING 子句

使用HAVING过滤分组

1.行已经被分组;

2.使用了组函数;

如:

select deptno,avg(sal) from emp group by deptno having avg(sal)>2000;

==========================================================================================

where 后面不能使用多行函数;

 

oracle数据库GROUP BY 子句

标签:包含   where   查询   使用   过滤   数据   第一个   avg   rom   

原文地址:https://www.cnblogs.com/curedfisher/p/11756740.html

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