肖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、百度

相关推荐
2401_8877245020 小时前
CSS如何设置文字溢出显示省略号_利用text-overflowellipsis
jvm·数据库·python
m0_7478545220 小时前
golang如何实现应用启动耗时分析_golang应用启动耗时分析实现思路
jvm·数据库·python
雪碧聊技术20 小时前
下午题_试题二
数据库
解救女汉子20 小时前
如何截断SQL小数位数_使用TRUNCATE函数控制精度
jvm·数据库·python
2301_8038756121 小时前
如何用 objectStore.get 根据主键 ID 获取数据库单条数据
jvm·数据库·python
weixin_4585801221 小时前
如何修改AWR保留时间_将默认8天保留期延长至30天的设置
jvm·数据库·python
qq_6543669821 小时前
C#怎么实现OAuth2.0授权_C#如何对接第三方快捷登录【核心】
jvm·数据库·python
justjinji21 小时前
如何用 CSS 变量配合 JS setProperty 实现动态换肤功能
jvm·数据库·python
2301_8038756121 小时前
C#怎么使用TopLevel顶级语句 C#顶级语句怎么写如何省略Main方法简化控制台程序【语法】
jvm·数据库·python
九皇叔叔21 小时前
MySQL 8.0 测试库安装
数据库·mysql