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的差别

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




以上是关于mysql经常使用查询:group by,左连接,子查询,having where的主要内容,如果未能解决你的问题,请参考以下文章

使用左连接连接表时如何正确查询 group by

MySQL调优--05---多表查询优化子查询优化 ORDER BY优化GROUP BY优化分页查询优化

如何使用 group_concat 和左连接计算 mysql 查询的结果

加速使用 Group By 和 Order By 的多表 Mysql 查询

带有连接和group by子句的选择查询中的MySQL性能问题

sql-多表查询JOIN与分组GROUP BY