MySQL系列(三)之15道常见笔试题

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: MySQL系列(三)之15道常见笔试题

前言

数据库的考察在面试时可是十分常见的,MySQL作为一种常用的关系型数据库管理系统,对于它的介绍在面试时可是必不可少的,下面就是一些常见笔试题的模拟,希望可以帮助到你🙂🙂

所用到的表如下:

学生表(t_mysql_student)

有学生ID(sid),学生姓名(sname),学生年龄(sage),学生性别(ssex)

教师表(t_mysql_teacher)

教师编号(tid),教师姓名(tname)

课程表(t_mysql_course)

课程编号(cid),课程名称(cname),教师编号(tid外键)

成绩表(t_mysql_score)

学生编号(sid外键),课程编号(cid外键),学生成绩(score)

1. 查询" 01 "课程比" 02 "课程成绩高的学生的信息及课程分数

select s.*,t1.score 01课程分数,t2.score 02课程分数 from  
(select *from t_mysql_score where cid='01')t1,
(select *from t_mysql_score where cid='02')t2,
t_mysql_student s
where s.sid=t1.sid and s.sid=t2.sid
and t1.score>t2.score

2. 查询同时存在" 01 "课程和" 02 "课程的情况

select s.*,t1.score 01课程分数,t2.score 02课程分数 from 
(select * from t_mysql_score where cid='01')t1,
(select * from t_mysql_score where cid='02')t2,
t_mysql_student s
where s.sid=t1.sid and s.sid=t2.sid

3. 查询存在" 01 "课程但可能不存在" 02 "课程的情况(不存在时显示为 null )

select t1.*,t2.score 02课程 from 
(select *from t_mysql_score where cid='01')t1 left join 
(select *from t_mysql_score where cid='02')t2 on
t1.sid=t2.sid

4. 查询不存在" 01 "课程但存在" 02 "课程的情况

select *from t_mysql_score s where s.sid not in
(select sid from t_mysql_score where cid='01')
and cid='02'

5. 查询平均成绩大于等于 60 分的同学的学生编号和学生姓名和平均成绩

select 
s.sid,s.sname,ROUND(AVG(sc.score)) 平均成绩
from
t_mysql_student s,t_mysql_score sc
where s.sid=sc.sid
GROUP BY
s.sid,s.sname
HAVING
平均成绩>60

6. 查询在t_mysql_score表存在成绩的学生信息

select *from t_mysql_student where sid in 
(select sid from t_mysql_score GROUP BY sid )

7. 查询所有同学的学生编号、学生姓名、选课总数、所有课程的总成绩(没成绩的显示为 null )

select 
s.sid,s.sname,count(sc.cid),sum(sc.score)
from
t_mysql_student s ,
t_mysql_score sc
where s.sid=sc.sid
GROUP BY
s.sid,s.sname

8. 查询「李」姓老师的数量

select count(*) from t_mysql_teacher where tname like '李%'

9. 查询学过「张三」老师授课的同学的信息

select 
s.*,t.tname
from
t_mysql_student s,t_mysql_teacher t,t_mysql_course c,t_mysql_score sc
where 
s.sid=sc.sid and t.tid=c.tid and c.cid=sc.cid
and tname='张三'

10. 查询没有学全所有课程的同学的信息

select 
s.sid,s.sname,count(sc.cid) 课程总数
from
t_mysql_student s,t_mysql_score sc
where s.sid=sc.sid
GROUP BY
s.sid,s.sname
HAVING
课程总数<(select count(1) from t_mysql_course)

11. 查询没学过"张三"老师讲授的任一门课程的学生姓名

select s.* from t_mysql_student s where s.sid not in (
select
sc.sid
from
t_mysql_teacher t,t_mysql_course c,t_mysql_score sc
where t.tid=c.tid and c.cid=sc.cid
and t.tname='张三'
GROUP BY
sc.sid)

12. 查询两门及其以上不及格课程的同学的学号,姓名及其平均成绩

SELECT
s.sid,s.sname,ROUND(AVG(sc.score)) 平均成绩,COUNT(sc.cid) 课程总数
FROM
t_mysql_student s,t_mysql_score sc
WHERE
s.sid=sc.sid and sc.score<60
GROUP BY
s.sid,s.sname
HAVING
课程总数>=2

13. 检索" 01 "课程分数小于 60,按分数降序排列的学生信息

SELECT
s.*
FROM
t_mysql_score sc,t_mysql_student s
WHERE
sc.sid=s.sid and sc.score<60 and cid='01'
ORDER BY sc.score DESC

14. 按平均成绩从高到低显示所有学生的所有课程的成绩以及平均成绩

SELECT
s.sid,s.sname,round(AVG(sc.score),2) 平均成绩 ,
max(case when sc.cid='01' then sc.score end)语文,
max(case when sc.cid='02' then sc.score end)数学,
max(case when sc.cid='03' then sc.score end)英语
FROM
t_mysql_score sc,t_mysql_student s,t_mysql_course c
WHERE
 sc.sid=s.sid and sc.cid=c.cid
GROUP BY
s.sid,s.sname
ORDER BY 平均成绩 desc

15. 查询各科成绩最高分、最低分和平均分:

-- 以如下形式显示:课程 ID,课程 name,最高分,最低分,平均分,及格率,中等率,优良率,优秀率。(及格为>=60,中等为:70-80,优良为:80-90,优秀为:>=90)

-- 要求输出课程号和选修人数,查询结果按人数降序排列,若人数相同,按课程号升序排列

SELECT
c.cid,c.cname,max(sc.score)最高分,
min(sc.score)最低分,
ROUND(AVG(sc.score))平均分,
count(sc.score)选修人数,
CONCAT(ROUND(sum(if(sc.score>=60,1,0))/count(sc.score)*100),'%')及格率,
CONCAT(ROUND(sum(if(sc.score>=70 and sc.score<80,1,0))/count(sc.score)*100),'%')中等率,
CONCAT(ROUND(sum(if(sc.score>=80 and sc.score<90,1,0))/count(sc.score)*100),'%')优良率,
CONCAT(ROUND(sum(if(sc.score>=90,1,0))/count(sc.score)*100),'%')优秀率
FROM
t_mysql_score sc,t_mysql_course c,t_mysql_student s
WHERE
sc.sid=s.sid and sc.cid=c.cid
GROUP BY
c.cid,c.cname
ORDER BY
选修人数 desc,
c.cid

CASE函数的详解

在MySQL数据库中,CASE函数是一种条件表达式函数,它允许根据条件的结果返回不同的值。CASE函数有两种形式:简单CASE表达式和搜索CASE表达式。

1. 简单CASE表达式:

简单CASE表达式用于对单个表达式进行多个条件的比较,语法如下:

CASE expression
    WHEN value1 THEN result1
    WHEN value2 THEN result2
    ...
    ELSE result
END

expression是需要进行比较的表达式(是可以省略的),value1、value2等是待比较的值,result1、result2等是满足条件时返回的结果,ELSE子句用于指定当没有条件匹配时的默认结果(也是可以省略的)。

用上面的第14题举例

case when sc.cid='01' then sc.score end

  • case后面的表达式和else后面的子句都进行了省略
  • sc.cid='01'是需要被比较的值,当它成立时,便输出sc.score

2. 搜索CASE表达式:

搜索CASE表达式用于根据多个条件进行比较,并返回满足条件的第一个结果。它的语法如下:

CASE
    WHEN condition1 THEN result1
    WHEN condition2 THEN result2
    ...
    ELSE result
END

condition1、condition2等是待比较的条件表达式,result1、result2等是满足条件时返回的结果,ELSE子句用于指定当没有条件匹配时的默认结果。

总结而言,CASE函数在MySQL数据库中用于根据条件返回不同的值。简单CASE表达式适用于对单个表达式进行多个条件比较,而搜索CASE表达式适用于根据多个条件进行比较。它们可以在SELECT语句中使用,并且可以与其他函数和条件表达式组合使用。

if函数详解

MySQL数据库中的IF函数是一个条件表达式函数,它允许根据条件的结果返回不同的值。IF函数的语法如下:

IF(condition, value_if_true, value_if_false)

condition是一个布尔表达式或条件,value_if_true是当条件为真时返回的值,value_if_false是当条件为假时返回的值。

用上面的第15题举例

if(sc.score>=60,1,0)

如果sc.score大于60分,就输出1,否则就输出0

总结而言,IF函数在MySQL数据库中用于根据条件返回不同的值,它可以在SELECT、INSERT、UPDATE等语句中使用,并且可以与其他函数和运算符组合使用。

一起进步吧!!!✌✌✌

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4月前
|
SQL 关系型数据库 MySQL
面试准备-MySQL
面试准备-MySQL
|
关系型数据库 MySQL
mysql题目实战2
mysql题目实战2
|
7月前
|
自然语言处理 搜索推荐 关系型数据库
|
关系型数据库 MySQL
MySQL练习题
MySQL练习题
81 0
|
关系型数据库 MySQL 数据库
MySQL学习笔记(二十)
MySQL学习笔记(二十)
135 0
MySQL学习笔记(二十)
|
SQL 算法 安全
看完这一篇,别在说你学过MySQL了(五)
大家好,我是Leo。目前在常州从事Java后端开发的工作。这篇是MySQL学习整理系列总结篇。这个系列会与字节,网易,阿里,腾讯,美团,快手的相关朋友一起整理输出。希望帮助更多的朋友早日入大厂!
看完这一篇,别在说你学过MySQL了(五)
|
SQL 存储 缓存
看完这一篇,别在说你学过MySQL了(二)
大家好,我是Leo。目前在常州从事Java后端开发的工作。这篇是MySQL学习整理系列的第二篇。这个系列会与字节,网易,阿里,腾讯,美团,快手的相关朋友一起整理输出。希望帮助更多的朋友早日入大厂!
看完这一篇,别在说你学过MySQL了(二)
|
存储 SQL 缓存
看完这一篇,别在说你学过MySQL了
大家好,我是Leo。目前在常州从事Java后端开发的工作。这篇是MySQL学习整理系列的第一篇。这个系列会与字节,网易,阿里,腾讯,美团,快手的相关朋友一起整理输出。希望帮助更多的朋友早日入大厂!
看完这一篇,别在说你学过MySQL了
|
存储 SQL 缓存
MySQL面试问题总结
MySQL面试经验总结
133 0
|
存储 SQL 自然语言处理
mysql 面试总结
前段时间找工作搜索 golang 面试题时,发现都是比较零散或是基础的题目,覆盖面较小。而自己也在边面试时边总结了一些知识点,为了方便后续回顾,特此整理了一下。
171 0
mysql 面试总结