MySQL语句难题终结者

因为一段时间不用mysql后有些东西会忘记,写来
一来为提供给以后加速回忆起相关语句
二来博各位大佬一笑

sql语句万能公式法

1 . sql语句三部分:what(要得到什么select后面的东西) from(从哪些表,最好直接join on )condition(where ,group by ,having,order by ,limit 这类十分easy 就没必要单独拿出来了)
举个栗子
select a.id ,a.name (what部分)
from t_student a join t_course b on t_student.cid =t_course.id (from 部分 基本就是直接写表名然后加上join ,再加你的条件)
where a.id>1 group by a.cid(一些条件语句)
2 .不行就用上面结果作为表再来一次select

ps:

  • 基本上select 和from 好写 ,难的是condition,也就是怎么把题意翻译成sql语句
  • 我的建议是先写where(主要是效率问题,where是先做把临时表筛选了),再写group by (注意group by 只是分组,所以数据还是那么多,只是每组只能显示该分组的第一条(毕竟数据库记录查出来是个二维结构,不能再立体了),所以聚合函数只能在group by 中用,因为where 根本就没有分组,怎么聚合),之后写分组后的having
  • 关于多表join 我建议甭管多少表,一次先join两个再来,把问题简单化(不知道这么做算不算最优解,暂时不考虑吧,但是一定是多表的万能解)

相关概念的解释,重要的例子

  • join on 和where
    直接贴个大佬写的吧,他写的还不错
    https://www.cnblogs.com/Jessy/p/3525419.html
  • where 和group by
    可见其实看过以上后,where的语句其实相当好写,问题再于group by 后面的聚合函数的应用,常见的聚合函数有哪些
    简单来说就五个,avg,count ,min,max,sum
    具体见这位大佬博客,介绍的很详细
    https://www.cnblogs.com/geaozhang/p/6745147.html
  • 集合中的交并补等,或者说是两个结果之间的运算
    这类问题也比较常见,单独整理下
    主要就是画下韦恩图,用左右连接,where 中写某些字段是不是null之类的条件
    这位大佬写的还行,就是没有具体的韦恩图,看着不是很形象,你们先看他的吧,我到时候自己写个更容易理解的,更方便的(要面试了,没时间)
    https://blog.csdn.net/sanzhongguren/article/details/76615464
  • 一道由于group by 只能查询聚合函数中的字段导致的问题
    三个字段,sid(学生id),cid(课程id) ,score(分数)
    在student_course表查询各科成绩最高的学生,结果列出学生id、课程id和对应的成绩 你可能会这样写:
    select sid,cid,max(score) from student_course group by cid;
    然而上面是不对的,因为 使用了group by的查询字段只能是group by中的字段或者聚集函数或者是每个分组内均相同的字段。 虽然不会报错,但是sid是无效的,如果去掉sid的话只能查出没门课程的最高分,不包含学生id。 本题的正确解法是使用相关嵌套查询:
    select * from student_course as x where score>=
    (select max(score) from student_course as y where cid=x.cid);
    相关子查询也就是在进行内层查询的时候需要用到外层查询,有一些注意事项:
    子查询一定要有括号
    as可以省略
    使用相关查询;>=max等价于>=all,但是聚合函数比使用any或all效率高
    相关子查询和嵌套查询见这位大佬的解释
    https://www.cnblogs.com/Ryan_j/archive/2010/10/20/1857026.html
    相当于()中的先在类中进行比较,再从外面的表拿数据
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容