• 肖sir__mysql之做题总结


    1、如果前面要用聚合函数(max/min/sum/avg/count/distinct)和字段 后面就要用group by分组,如只有聚合函数,则可不用
    2、取最大值时使用max命令,也可以用order by 排序,然后用limit命令取第一行
    3、找最大值或最小值时先排序
    4、
    5、子查询:select 要显示的字段1 from 表1 where 字段2=(select 字段3 from 表2 where 条件)
    6、不能使用where对分组后的结果进行过略,不能在where中使用组函数(group by后不能跟where)
    7、having是专门用来对分组后的结果进行过滤,having可以单独使用不和group by配合

    步骤:
    1、先确定条件:where 接条件
    2、合表:inner join;left join;right join;
    3、判断是否需要排序、分组,先分组再排序
    4、最后写需要的字段,select 字段

    ========================================
    一、判断结果:
    判断所需的结果是一个字段值、一列,一行,还是表。根据子查询选择合适的句式结构
    1)若结果含字段和函数:则条件中需要存在group by进行分组(因分组的字段会进行排序)
    2)若结果只含字段或函数:则根据需要的结果判断是否加入子查询的句式
    3)根据结果判断,进行操作是否需要进行多表关联

    二、判断条件:是否需要进行分组,排序,比较
    判断条件语句的选择
    1)group by:
    【1】后面可接 order by进行排序
    【2】having 根据原句式进行
    【3】是否需要进行二次排序
    2)where:
    【1】比较运算符
    【2】逻辑运算符
    3)order by:
    【1】desc:降序排列
    【2】asc:升序排列
    在取最大最小的时候 可以进行排序后取第一个

    三、子查询
    将一个字段值,一个字段的多个数据,多个字段的一组数据或一张表作为条件进行操作
    1)标量子查询:
    根据需要的结果判断是否是一个字段值来选择是否使用
    2)列子查询
    根据需要的结果判断是否为一个字段的多个数据来选择是否使用
    3)行子查询
    根据需要的结果判断是否为多个字段的一组数据来选择是否使用
    4)表子查询
    万物皆可表子查询,上述连接皆可以用表子查询代替
    需要将作为返回值的表作为一个条件进行操作,并为其取一个新表名

    四、连接
    1)内连接
    隐藏内连接:select * from a,b where a.N=b.M----------------------查询a表和b表相同的关联字段N,M
    普通内连接:select * from a inner join b on a.N=b,M---------------查询a表和b表相同的关联字段N,M
    2)左连接 left join on
    右连接 right join on
    左(右)独有连接:将左(右)表作为主表,已主(左)表上显示的null来获取副(右)表的独有数据

    总结:先看结果,判断是否关联,根据条件选择是否使用子查询(表子查询万能),再进行编写
    结果和条件单拎出来分析具体需要的字段和内容

    ========================================
    1、理清提议
    2、题意要求
    3、找条件
    4、步骤清晰有条理
    5、聚合函数要与group by一起使用
    6、百度

  • 相关阅读:
    Visual Studio System.Diagnostics.Debug卡顿问题
    RHCE8 资料整理(四)
    推荐2款.NET开源、轻便、实用的Windows桌面启动器
    安卓文件权限总结
    【PostgreSQL】PostgreSQL 15移除了Stats Collector
    【深度学习基础知识(一):卷积神经网络CNN基础知识】
    OpenCV图像处理学习十八,霍夫变换实现交通车道线检测
    Vue根据条件更改列表明细某一行的背景颜色-简单实现
    [UEFI]EFI_DEVICE_PATH_PROTOCOL 结构体初始化的一个例子
    调整屏幕的宽高比
  • 原文地址:https://blog.csdn.net/m0_47403059/article/details/134686181