文档详情

第8讲 SQL 分组统计查询.ppt

发布:2017-05-03约3.75千字共21页下载文档
文本预览下载声明
课堂练习 1、在学生成绩表中查询选修了101课程,成绩前十名的学生信息。 2、根据年龄由大到小的顺序,年龄相同的按学号的升序列出学生信息表中的数据。 请大家考虑下面问题 如何在查询中获得以下结果? 计算学生平均年龄 查找成绩最大值 计算成绩总和 统计表的行数 ……. 聚合函数 使用聚合函数举例 统计学生信息表中的总人数 Select count(*) from stu_info 统计学生信息表中地址不为空的人数 Select count(s_addr) from stu_info 计算学生信息表中男生的平均年龄 Select avg(age) from stu_info Where sex=‘男’ 计算成绩表中0702301101学生的总成绩 Select sum(score) from stu_score Where s_id=‘0702301101 ’ 使用聚合函数 使用 GROUP BY 子句 请思考下面题目: 查询学生信息表中男,女生的人数 查询学生信息表中每个班级中男,女生各自的人数 查询学生成绩表中每位学生的总成绩 查询学生成绩表中总成绩高于500分的学生名单 总体思路: 先分组后统计(如何分组呢?) 使用 GROUP BY 子句 使用 GROUP BY 子句(续) 使用 GROUP BY 子句和 HAVING 子句 使用 GROUP BY 子句和 HAVING 子句 使用ORDER BY子句对查询结果排序 聚合函数的使用 使用GROUP BY子句对查询结果分组(难点) 使用HAVING子句筛选结果表 第8讲 分组统计查询 思考: 在学生成绩表中查询选修了101课程,成绩前十名的学生信息。 查找数据思路: 使用where子句查找选修101课程的学生 对所有选修101课程的学生排序(如何排序?) 使用top n关键字列出前十名 order by—对数据进行排序 使用 ORDER BY 子句为结果集中的行排序,有升序(ASC)和降序(DESC)两种。 使用ORDER BY 子句时,注意: (举例) SQL Server 缺省地按升序排列 ORDER BY 子句中指定的列并不一定要出现在选择列表中 可以按照计算出的值或多个字段进行排序 可以在 ORDER BY 子句中引用某字段在选择列表中的位置而进行排序 ORDER BY 子句指定的列不能超过8060字节 ORDER BY 子句不能用于数据类型 text 或 image 字段 order by—对数据进行排序(续) 学号 姓名 性别 年龄 数学成绩 语文成绩 S001 王清 男 19 75 60 S002 张凡 男 18 80 75 S003 李丽 女 18 65 80 S004 赵刚 男 20 90 78 S005 孙晓芳 女 19 85 80 学生表: Order by ——默认按升序例子 如果不指定排序方式,则默认按升序排列 select * from 学生表 order by 数学成绩+语文成绩 排序结果: 学号 姓名 性别 年龄 数学成绩 语文成绩 S001 王清 男 19 75 60 S003 李丽 女 18 65 80 S002 张凡 男 18 80 75 S005 孙晓芳 女 19 85 80 S004 赵刚 男 20 90 78 Order by —字段名 按照字段名进行排序 select * from 学生表 order by 数学成绩 DESC 排序结果: 学号 姓名 性别 年龄 数学成绩 语文成绩 S004 赵刚 男 20 90 78 S005 孙晓芳 女 19 85 80 S002 张凡 男 18 80 75 S001 王清 男 19 75 60 S003 李丽 女 18 65 80 Order by —表达式 按表达式排序: select * from 学生表 order by 数学成绩+语文成绩 DESC 排序结果: 学号 姓名 性别 年龄 数学成绩 语文成绩 S004 赵刚 男 20 90 78 S005 孙晓芳 女 19 85 80 S002 张凡 男 18 80 75 S003 李丽 女 18 65 80 S001 王清 男 19 75 60 Order by ——多个字段 按多个字段排序: select * from 学生表 order by 数学成绩 DESC,语文成绩 DESC 排序结果: 学号 姓名 性别 年龄 数学成绩 语文成绩 S004 赵刚 男 20 90 78 S005 孙晓芳 女 19 85 80 S002 张凡 男 18 80 75 S003 李丽 女 18 65 80 S00
显示全部
相似文档