首页 > 代码库 > 福州大学第十一届程序设计竞赛菜鸟的题解
福州大学第十一届程序设计竞赛菜鸟的题解
前几天去了两个比较牛的互联网公司面试,在sql这块都遇到问题了,哎,可惜呀,先把简单的梳理一下
成绩表 score
1、group by 使用
按某一个维度进行分组
例如:
求每个同学的总分
SELECT student,SUM(score) FROM score GROUP BY student
求每个同学的平均分
SELECT student,AVG(score) FROM score GROUP BY student
也可以按照 班级,课程 来求
2、having 与 where的区别
having与where类似,可以筛选数据,where后的表达式怎么写,having后就怎么写
- where针对表中的列发挥作用,查询数据
- having对查询结果中的列发挥作用,筛选数据
查出挂了两门及以上的学生
SELECT student,SUM(score<60)as gk FROM score GROUP BY student HAVING gk>1
3、子查询
(1)where子查询
(把内层查询结果当作外层查询的比较条件)
求比每门课程平均分低的学生
SELECT student ,course, score
FROM score ,(SELECT course AS a_course,AVG( score)AS a_score FROM score GROUP BY course) AS avg_score
WHERE course = a_course AND score<a_score
先写到这吧
可以参考
http://www.cnblogs.com/rollenholt/archive/2012/05/15/2502551.html
福州大学第十一届程序设计竞赛菜鸟的题解
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。