ORDER BY 子句

3.ORDER BY 子句

对查询结果按照一个或多个属性列的升序(ASC)或降序 (DESC) 排列。

*默认值为升序

ORDER BY Grade DESC

★对于空值 排序时显示的次序由具体系统实现来决定

  • 若按升序排,含空值的元组最后显示
  • 若按降序排,空值的元组最先显示

4.聚集函数

COUNT(*) 统计元组个数
COUNT(  [DISTINCT|ALL]  <列名> )统计一列中值的个数
SUM( [DISTINCT|ALL]  <列名> )计算一列值的总和(此列必须时数值型)
AVG(  [DISTINCT|ALL]  <列名> )计算一列值的的平均值(此列必须时数值型)
MAX(  [DISTINCT|ALL]  <列名> )求一列值中的最大值
MIN(  [DISTINCT|ALL]  <列名> )求一列值中的最小值

指定 DISTINCT ,表示 “在计算时要取消指定列中的重复值”。

不指定 DISTINCT或者指定 ALL(ALL为默认),则表示“不取消重复值”。

[Tips]①COUNT后面的小括号和“*”不可省略。

        ②2、3、4行中“DISTINCT”有或没有,区别很大!

例1. 查询学生总人数:

   SELECT COUNT(Sno) 

   FROM Student

当聚集函数遇到空值时,除了COUNT(*)外,都跳过空值而只处理非空值。

例:30,20,null

 则COUNT(  [DISTINCT|ALL]  <列名> )=2!        不是3

AVG(  [DISTINCT|ALL]  <列名> )=(30+20)/2

注意:WHERE 子句中是不能用聚集函数作为条件表达式

聚集函数只能用于:①SELECT 子句

                                ②GROUP BY中的HAVING 子句

                                ③ORDER BY 后

                                ④直接 GROUP BY  后也可以

5.GROUP BY 子句

将查询结果按某一列或多列的值分组,值相等的为一组

对查询结果分组的目的是为了细化聚集函数的作用对象。如果未对查询结果分组,聚集函数将作用于整个查询结果。分组后聚集函数将作用于每一个组,即每一组都有一个函数值。

例2.求各个课程号及相应的选课人数

       SELECT Cno,COUNT(Cno)

       FROM SC

       GROUP BY Cno;

[例3.47]查询选修了3门以上的课程的学生学号
答案:SELECT  Sno 
          FROM   SC
          GROUP BY Sno
          HAVING COUNT(*)>3;

HAVING短语是选择出满足条件的组

这里即是先按学号分组,然后HAVING将满足(选课>3)的组选出来

HAVING 与 WHERE   区别

    在于  作用对象不同

  • HAVING短语作用于组,从中选择出满足条件的组
  • WHERE短语作用于基本表或者视图,从中选择出满足条件的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值