count 求某列的行数
sum 对某列数据求和
avg 求某列数据的平均值
max 求某列数据的最大值
min 求某列数据的最小值
一.汇总分析
计数函数count:
*注 如果count函数中输入的是列名,得到的是去除空值后的行数,其他所有的汇总函数也是,如果输入的是列名会提前把NULL排除在外,再进行计算。
输入*会计算空值
求和函数sum:
最大值max 最小值min:
去重计数count(distinct 列名 ):
其他汇总函数也可以这么用,在列名前面加上distinct
总结
1.汇总函数输入列的时候,是把NULL去除后计算
2.sum avg 只能对数值类型计算
3.max min 可以对任何类型进行计算(日期、字符串)
课后练习:
查询课程编号为“0002”的总成绩
查询选了课程的学生人数
二.分组 group by
查询各科成绩最高和最低的分
查询每门课程被选修的学生数
查询男生、女生人数
三.对分组结果指定条件
where只能指定行的条件,having能够指定分组后需要哪一组
练习:
查询平均成绩大于60分学生的学号和平均成绩
查询至少选修两门课程的学生学号
查询同名同姓学生名单并统计同名人数
四.用sql解决业务问题
1.翻译成大白话
2.写出分析思路
3.写出对应的sql子句
分析思路:
如何计算各科的平均成绩
翻译:
如何计算每门课程的平均成绩
分析思路:把关键词放到对应的sql关键词后面
五.对查询结果排序 order by
降序desc 升序asc
运行顺序:
指定多个排序列名:
order by 成绩 asc,课程号 desc; 从左到右依次排列
从查询结果中取出指定行:limit
SQL运行顺序
1.先运行篮框里的子句,子句按照书写顺序运行
2.select 子句
3.最后运行红框里的子句
练习:理解sql的运行顺序
查询不及格的课程并按课程号从大到小排列
查询每门课程的平均成绩,结果按平均成绩升序排序,平均成绩相同的按课程号降序排列
六.如何读懂报错
1.在group by 中使用了select里的别名
因为having子句在select子句之前运行,所以不知道平均成绩是什么
2.常见问题:字符串类型的数字
字符串类型和数值类型的排序规则不同,需要先修改字符串类型为数值类型