mysql经常使用查询:group by,左连接,子查询,having where
Posted claireyuancy
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql经常使用查询:group by,左连接,子查询,having where相关的知识,希望对你有一定的参考价值。
前几天去了两个比較牛的互联网公司面试。在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的差别
- 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
以上是关于mysql经常使用查询:group by,左连接,子查询,having where的主要内容,如果未能解决你的问题,请参考以下文章
MySQL调优--05---多表查询优化子查询优化 ORDER BY优化GROUP BY优化分页查询优化
如何使用 group_concat 和左连接计算 mysql 查询的结果
加速使用 Group By 和 Order By 的多表 Mysql 查询