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短语作用于基本表或者视图,从中选择出满足条件的元组