美文网首页
MySQL语句难题终结者

MySQL语句难题终结者

作者: 满足我写点东西的需求 | 来源:发表于2018-09-14 23:50 被阅读0次

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

相关文章

  • MySQL语句难题终结者

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

  • php操作mysql语句

    mysql语句 php操作mysql语句

  • 2018-03-20

    MYSQL查询语句 MYSQL复杂操作语句 MYSQL多表查询方法 函数部分

  • BigData-MySQL总结大全(一)苏暖人

    BigData之MySQL总结大全 MYSQL常用的基本语句 MYSQL常用的基本语句 例:SELECT TOP ...

  • mysql常用语句

    一、Mac端:打开MYSQL服务器语句:brew services start mysql关闭MYSQL服务器语句...

  • MySQL常用语句

    MySQL常用语句 tags: MySQL 常用语句 语法 随便写的标签 建表 insert 语句 msyql 把...

  • MySQL基础——DML语句

    上篇文章我们学习了MySQL基础——DDL语句,这篇文章学习MySQL基础——DML语句。 DML语句 DML英文...

  • MySQL基础——DCL语句

    上篇文章学习了MySQL基础——DQL语句,这篇文章学习MySQL基础——DCL语句。 DCL语句 DCL英文全称...

  • MySQL基础——DQL语句

    在上篇文章中,我们学习了MySQL基础——DML语句,这篇文章学习MySQL基础——DQL语句。 DQL语句 DQ...

  • Linux [MySQL]

    @[TOC](Linux [MySQL]) Database MySQL 注意: MySQL 的SQL语句以分号...

网友评论

      本文标题:MySQL语句难题终结者

      本文链接:https://www.haomeiwen.com/subject/lvoagftx.html