zoukankan      html  css  js  c++  java
  • 写SQL的套路

    定义问题

    转化问题

    如要解决的问题是:查出每门课程成绩都大于80分学生的姓名,可以转化为:只要学生最小分数的课程大于80分,就是所有课程成绩都大于80分。
    查询同名同姓学生名单并统计同名人数-->怎么算姓名相同?按姓名分组后人数大于等于2,因为同名的人数大于等于2,分析出这一点很重要

    分解问题

    如要解决的问题是:查询出两门课程以上不及格的学生姓名和其平均成绩
    先分解题目:
    1)[两门以上][不及格课程]限制条件
    2)[同学的学号及其平均成绩],也就是每个学生的平均成绩,显示学号,平均成绩
    分析过程:
    第1步:得到每个学生的平均成绩,显示学号,平均成绩
    第2步:再加上限制条件:
    1)不及格课程
    2)两门以上[不及格课程]:课程数目>2

    使用以下套路

    select 查询结果
    from 从哪张表中查找数据
    where 查询条件
    group by 分组
    having 对分组结果指定条件
    order by 对查询结果排序
    limit 从查询结果中取出指定行

    sql执行顺序

    (1)from
    (2)on
    (3)join
    (4)where
    (5)group by(开始使用select中的别名,后面的语句中都可以使用)
    (6)avg,sum....
    (7)having
    (8)select
    (9)distinct
    (10)order by
    (11)limit

  • 相关阅读:
    谈一谈网站防盗链
    SEO优化步骤
    hls协议(最清晰的讲解)
    https比http到底那里安全?
    常见的php攻击(6种攻击详解)
    36)django-jsonp跨域
    35)django-验证码
    34)django-上传文件,图片预览功能实现
    33)django-原生ajax,伪ajax
    32)django-modelform
  • 原文地址:https://www.cnblogs.com/Uni-Hoang/p/14321304.html
Copyright © 2011-2022 走看看