ORACLE数据库 —— 排序与分组

1 篇文章 0 订阅
1 篇文章 0 订阅

一、排序查询

1.关键字:order by

2.排序方式:asc 升序,可省略;desc 降序,不可省略

3.注意:order by中的字段与select中的字段无关

select empno from emp order by sal;

对同一个字段进行多次排序,只有第一个排序有效

select empno,sal from emp order by sal,sal desc

二、分组查询

1.关键字:group by

2.聚合函数

(1)sum():求和

(2)max():求最大值

(3)min():求最小值

(4)avg():求平均值

(5)count(*/常量/字段):统计总数,统计的字段不能为空,不可能出现空值

                性能比较:count(*)<count(字段)<count(常量)

所有的聚合函数都是针对非空字段进行的

3.having

        having与group by子句联合使用,用来过滤分组之后的数据

4.若SQL语句中含有group by子句,此时select子句仅能出现

(1)group 奴役子句中出现的字段

(2)聚合函数

(3)常量

示例:如果group by中的字段,没有出现在select子句中则会报错

                select ename,sal from emp group by deptno;

                        --不是group by表达式

5.在SQL语句中,select子句中含有聚合函数,但是并没有出现group by子句的情况,select中不能出现聚合函数和常量以外的字段。

                select ename,count(*) from emp;

                        --不是单租分组函数

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我看你与我有缘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值