Where/Order by/Ggroup by/Having使用的注意事项
繁花似锦的夏季来临,瓦楞纸盒,常州汽车站官网
1、where、order by、group by 、having
where作用对象是:基本表或视图,从中选出符合条件的元素。
order by 作用对象是:基本表或视图,就是排序方式,分为升序(asc)和降序(desc),排序默认为升序
group by 作用对象是:基本表或视图,把对象进行分组(一个或多个字段)。
having 作用对象是 组,从中选择符合条件的组
注意事项:
- group by 与having连用选出符合条件的分组;
- group by 必须与聚合函数(sum,avg,min,max,cout)一起使用才有意义,使用时至少需要一个分组标志;
- group by 与where 一起使用时:
【3.1】一起使用时,where在前group by 在后;
【3.2】注意having和where的用法区别;
(3.2.1)having只能用在group by 之后,对分组的结果进行筛选{即使用having的前提条件是分组};
(3.2.2)where肯定再group by之前;
(3.2.3)where后的条件表达式里不允使用聚合函数,而having可以;
【3.3】当一个查询语句同事出现了where,group by,having,order by的时候,执行顺序和编写顺序是:
<where--group by---having--order by>
(1) 执行where xx对全表数据做筛选,返回第1个结果集。
(2) 针对第1个结果集使用group by分组,返回第2个结果集。
(3) 针对第2个结果集中的每1组数据执行select xx,有几组就执行几次,返回第3个结果集
(4) 针对第3个结集执行having xx进行筛选,返回第4个结果集。
(5) 针对第4个结果集排序。
如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!!
点击进行留言回复
相关文章:
-
-
-
快速向表插入大量数据
当需要对一个非常大的表INSERT的时候,会消耗非常多的资源,因为update表的时候,oracle需要生成 redo log和undo log;此时最...
[阅读全文]
-
-
-
Oracle入门学习五
学习视频: https://www.bilibili.com/video/BV1tJ411r7EC?p=55 数据的完整性:保证插入表格的数据必须正确。...
[阅读全文]
-
Oracle入门学习六
事务:把一组操作看做一个工作单元,要么都执行,要么都不执行。dml操作才有事务,查询没有事务。 开始事务:从上一次的事务结束之后,从第一次dml操作,就...
[阅读全文]
-
-
-
Oracle入门学习一
oracle的安装,用户授权,表格操作,数据类型,ddl表格,dml数据。 下一篇:Oracle入门学习二 学习视频:https://www.bilib...
[阅读全文]
-
Oracle入门学习二
上一篇:Oracle入门学习一 学习视频:https://www.bilibili.com/video/BV1tJ411r7EC?p=15 算术运算符:...
[阅读全文]
网友评论