MySQL第五战:常见面试题(下)

前言:

在当今的IT世界,数据库是任何应用程序的核心。而MySQL,作为最流行的开源关系数据库管理系统,已经成为许多开发者和企业的首选。无论是初创公司还是大型企业,都依赖于MySQL来存储、管理和检索数据。

随着技术的不断发展,MySQL的复杂性和功能也在持续增长。为了更好地理解和应用MySQL,许多开发者会寻求各种资源,包括书籍、在线教程和面试题。本文,我们将深入探讨一些常见的MySQL面试题,帮助你巩固知识,提升技能,为你的技术面试做好准备。

在开始之前,请注意,这只是一个概览,并不能涵盖所有的细节。对于深入的学习和理解,我建议你参考官方文档、专业书籍和在线教程。

现在,让我们开始这场关于MySQL的第五战------常见面试题之旅吧!

09)查询学过「张三」老师授课的同学的信息
sql 复制代码
SELECT

s.*,c.cname,t.tname

FROM

t_mysql_teacher t,t_mysql_student s,t_mysql_course c,t_mysql_score sc

WHERE

t.tid=c.tid and c.cid=sc.cid and sc.sid=s.sid and tname = '张三'
10)查询没有学全所有课程的同学的信息
sql 复制代码
SELECT

s.sid,s.sname,count(sc.score) n

FROM

t_mysql_score sc,t_mysql_student s

WHERE

sc.sid=s.sid

GROUP BY

s.sid,s.sname

HAVING

n<(select count(c.cid) from t_mysql_course c )
11)查询没学过"张三"老师讲授的任一门课程的学生姓名

思路:1.查询学过张三老师课程的学生 2.not in

sql 复制代码
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)查询两门及其以上不及格课程的同学的学号,姓名及其平均成绩
sql 复制代码
SELECT

s.sid,s.sname,ROUND(AVG(sc.score)) 平均成绩,COUNT(sc.cid) n

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

n>=2
13)检索" 01 "课程分数小于 60,按分数降序排列的学生信息
sql 复制代码
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)按平均成绩从高到低显示所有学生的所有课程的成绩以及平均成绩

思路:查询学生信息,课程信息,学生每个课程成绩,学生平均成绩

sql 复制代码
SELECT
s.sid,s.sname,round(AVG(sc.score),2) avgNum ,
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 avgNum desc
 
 
SELECT
s.sid,s.sname,round(AVG(sc.score),2) avgNum ,
max(if(sc.cid='01',sc.score,0))语文,
max(if(sc.cid='02',sc.score,0))数学,
max(if(sc.cid='03',sc.score,0))英语
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 avgNum desc
15)查询各科成绩最高分、最低分和平均分:

以如下形式显示:课程 ID,课程 name,最高分,最低分,平均分,及格率,中等率,优良率,优秀率及格为>=60,中等为:70-80,优良为:80-90,优秀为:>=90
要求输出课程号和选修人数,查询结果按人数降序排列,若人数相同,按课程号升序排列

思路:

1.max,min,avg

2.将课程 ID,课程 name当做分组字段

3.获取及格人数,中等人数,优良人数,优秀人数

sql 复制代码
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,
相关推荐
言之。5 小时前
Django中的软删除
数据库·django·sqlite
阿里嘎多哈基米7 小时前
SQL 层面行转列
数据库·sql·状态模式·mapper·行转列
抠脚学代码7 小时前
Ubuntu Qt x64平台搭建 arm64 编译套件
数据库·qt·ubuntu
jakeswang7 小时前
全解MySQL之死锁问题分析、事务隔离与锁机制的底层原理剖析
数据库·mysql
Heliotrope_Sun8 小时前
Redis
数据库·redis·缓存
一成码农8 小时前
MySQL问题7
数据库·mysql
吃饭最爱8 小时前
JUnit技术的核心和用法
数据库·oracle·sqlserver
专注API从业者8 小时前
Python/Java 代码示例:手把手教程调用 1688 API 获取商品详情实时数据
java·linux·数据库·python
雨落Liy8 小时前
SQL 函数从入门到精通:原理、类型、窗口函数与实战指南
数据库·sql
Kt&Rs9 小时前
MySQL复制技术的发展历程
数据库·mysql