因为一段时间不用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
相当于()中的先在类中进行比较,再从外面的表拿数据