sql where中用case_SQL-常见面试题小结

一、简单查询

(一)表的创建、修改、删除

创建表

CREATE TABLE 表名 (列名1 数据类型(长度),列名2 数据类型(长度),…..);

2、删除表:DROP TABLE 表名

3、 修改表:ALTER TABLE 表名ADD 列名 数据类型/DROP COLUMN 列名

(二)表数据的插入、删除、更新

1、插入数据:INSERT INTO 表名(列名1,列名2,….) VALUES(值1,值2,….)

2、删除数据:DELETE FROM 表名称 WHERE 列名称 = 值

3、修改数据:UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值

v2-c1892d2354ce0c0870c29ea334202c17_b.jpg

v2-cfc6e1af755397d61778083a689e6a51_b.jpg

PS:建立了course, score, student, teacher四个表,后续再此基础上练习sql语句。

4、通配符在sql中运用(模糊查询)

Select 列名1,列名2,…..From 表名 Where 列名 like 条件

PS:

(1) like与%

① %猴:已猴结尾;

② 猴%,已猴开始;

③ %猴%,包含猴;

(2)like与下划线():下划线表示任意一个字符

v2-010eab5e54ccfa978921ec047db146a6_b.jpg

v2-d9abf583f1bb64f05cbd06b64d439496_b.jpg

二、汇总分析

运算符介绍:

算术运算符:加(+)、减(-)、乘(*)、除(/);

比较运算符:等于(=)、不等于(<>)、大于(>)、大于等于(>=)、小于(<)、小于等于(<=);

逻辑运算符:否定某一条件(not)、并且(and)、范围查询(between)、或者(or、in);

函数介绍:

Select count/ sum/ avg/max/min 列名From 表名;

1、汇总

v2-64ef68d330bb66a3d1011822fa43b066_b.jpg

2、分组

v2-41658efea17e63ff4e513446faf58914_b.jpg

3、分组指定条件

v2-fda69400001899547516b947cb7f3717_b.jpg

4、 排序

v2-cee73dda698b465007a194371fcc1a9a_b.jpg

5、 综合

v2-ad6f402cb8f714e69f4daeddefcb37f7_b.jpg

三、复杂查询

(一) 语法

Select count/ sum/ avg/max/min 列名

From 表名

Where 查询条件

Group by 分组条件

Having 对分组结果指定条件

Order by 对查询结果进行排序(asc升序排列,desc降序排列)

Limit 取指定行

1、子查询:

v2-c0cc7b817608507df38716747b41eda6_b.jpg

四、面试的topN问题

v2-f53e1b15947d830b474c7cfe9b69e9fa_b.jpg

五、多表查询

1、子查询:当需要将一个查询的结果作为另一个查询的数据来源或判断条件时使用(in、any、all)

2、标量子查询:返回单一值。

3、关联子查询:每个组里比较。

4、联结

记住这张表:

v2-90a62c132629ce822e4511df73888e56_b.jpg

v2-88f6840e0c02e468436ad54cc628847b_b.jpg

6、 case表达式:当有多种情况,需要进行条件判断时。

Case when <判断表达式> then <表达式>

when <判断表达式> then <表达式>……..

else <表达式>

end

六、行列转化

步骤:输出目标表的结构——将常量替换为成绩(case表达式)——分组

v2-474fc65f7a736544416a35abadfbb9f8_b.jpg

最后请记住sql语句的运行顺序

v2-49ef023f72562c2214083b3bd49cdd89_b.jpg
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值