软件测试肖sir__010之mysql之总结(8)

mysql数据库:总结
案例1:
判断题目中的条件和结果
一、判断结果:
判断所需的结果是一个字段值、一列,一行,还是表。根据子查询选择合适的句式结构
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来获取副(右)表的独有数据

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

======================================================
案例2:
多表练习题个人总结
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 字段

======================================================
案例3:
练习总结:

  1. 聚合函数不能和查询字段一起放在select后面,除非聚合函数被分组,否则字段会按照表格默认进行排序,导致数据错乱;
  2. Where和having:
    ①不能使用where子句对分组后的结果进行过滤。不能在where子句中使用组函数;
    ②having子句:专门用来对分组后的结果进行过滤。having可以单独使用而不和group by配合。
  3. 大致使用顺序: WHERE 子句用来筛选 FROM 子句中指定的操作所产生的行GROUP BY 子句用来分组 WHERE 子句的输出HAVING 子句用来从分组的结果中筛选行;
  4. From后接整个语句必须使用(…)as 别名来建立临时表;
  5. 字段类型中,字符输入需添加引号,数值不用;
  6. 找最大值最小值时使用limit可能会忽略重复的部分,尽量作为备选方案。
    ======================================================
    案例4:
    1.where 在order by语句之前
    2.派生表进行连接时,使用的是原始表
    3.派生表需要取别名
    4.Group by 进行分组时 默认选取第一个
    5.每一个条件都是独立的,不存在联系
    6.条件不能进行连续判断 0< X < 1
    7.子查询往往是表与表之间有相同的字段并作为条件进行查询
    8.列子查询 查询结果为列 使用in 行子查询用 =any 查询结果为行

======================================================
案例5:
软件测试肖sir__010之mysql之总结(8)_第1张图片

案例6:
1.聚合函数不可以跟一起使用(除分组的字段),因为(除分组的字段)不排序,默认选择第一个。分开使用单独求出 max的值,可用 in =
2.取最大值时 使用max命令。也可以用排序法:order by 排序 然后使用limit命令,取第一行。
排序法只能适用最大值只有一个,如果有多个最大值只会显示一条。
3.注意区别 内连接 左连接 右连接 的内容不一样
4.Group by 条件 后面可以接 order by 表示 分组后排序 也可以接 having
5.括号括起来的语句必须可执行
6.每一个表都可以取别名
7.字符要加引号
8.审题要仔细,看清楚条件意思,再考虑思路

======================================================
案例7:
软件测试肖sir__010之mysql之总结(8)_第2张图片

你可能感兴趣的:(笔记,r语言,mysql,开发语言)