- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第8讲 SQL 分组统计查询
课堂练习 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
文档评论(0)