MySQL常见笔试题

前言

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

所用到的表如下:

学生表(t_mysql_student)

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

MySQL常见笔试题_第1张图片

 教师表(t_mysql_teacher)

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

MySQL常见笔试题_第2张图片

 

 课程表(t_mysql_course)

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

MySQL常见笔试题_第3张图片

 

 成绩表(t_mysql_score)

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

MySQL常见笔试题_第4张图片

 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等语句中使用,并且可以与其他函数和运算符组合使用。

一起进步吧!!!✌✌✌

你可能感兴趣的:(mysql,数据库)