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

  • 相关阅读:
    eWebEditor漏洞
    远程连接SQL Server
    eWebEditor漏洞
    【Demo 0009】绘图对象调色板
    【Demo 0001】 获取命令行参数
    【Demo 0007】绘图对象 画笔
    【Demo 0005】Win32 程序结构封装
    【Demo 0006】图形绘制基础
    【Demo 0008】绘图对象–画刷
    【Demo 0004】Windows 消息机制(2)
  • 原文地址:https://www.cnblogs.com/Uni-Hoang/p/14321304.html
Copyright © 2011-2022 走看看