要想学会MySQL这项技能,只有在不断的实践练习中才能牢固掌握知识,光看不练是假把式!所以,请先在数据库中创建以下练习需要使用的4个表,一边进行复习,一边进行练习:


一、简单查询习题练习

1、查找姓‘猴’的学生名单

SELECT 学号,姓名
FROM student
WHERE 姓名 LIKE '猴%' ;

2、查询姓名中最后一个字是‘猴’的学生名单

SELECT 学号,姓名
FROM student
WHERE 姓名 LIKE '%猴' ;

3、查询姓名中带‘猴’的学生名单

SELECT 学号,姓名
FROM student
WHERE 姓名 LIKE '%猴%' ;

4、查询姓‘王’的学生名单,并且名字是3个字的

SELECT 学号,姓名
FROM student
WHERE 姓名 LIKE '王__' ;-- 王后面接了两个下划线

5、查询姓‘孟’的老师的个数

SELECT 教师姓名,COUNT(教师号) AS 教师个数
FROM teacher
WHERE 教师姓名 LIKE '孟%' ;


二、汇总查询习题练习

1、查询课程号为‘0002’的总成绩

SELECT 课程号,SUM(成绩) AS 总成绩
FROM score
WHERE 课程号 = '0002' ; 

2、查询选了课程的学生人数

SELECT COUNT(DISTINCT 学号) AS 学生人数
FROM score
WHERE 课程号 IS NOT NULL;-- 去除课程号为空值的数据,即学生没有选课的数据

本表为演示效果,增加0004学号的数据,课程号和成绩为空值

3、查询各个课程成绩最高和最低的分

SELECT 课程号,MAX(成绩) AS 最高分,MIN(成绩) AS 最低分
FROM score
GROUP BY 课程号;

4、查询每门课程选修的学生人数

SELECT 课程号,COUNT(学号) AS 学生人数
FROM score
GROUP BY 课程号;

5、查询男生、女生人数

SELECT 性别,COUNT(姓名) AS 学生人数
FROM student
GROUP BY 性别;

6、查询平均成绩大于60分学生的学号和平均成绩(平均成绩保留两位小数)

SELECT 学号,ROUND(AVG(成绩),2) AS 平均成绩
FROM score
GROUP BY 学号
HAVING AVG(成绩) > 60;

7、查询至少选修两门课程的学生学号

SELECT 学号,COUNT(课程号) AS 选修课程数
FROM score
GROUP BY 学号
HAVING COUNT(课程号) >= 2;

8、查询同名同姓学生名单并统计同名人数

SELECT 姓名,COUNT(姓名) AS 同名人数
FROM student
GROUP BY 姓名
HAVING COUNT(姓名) >= 2;

9、查询不及格的课程并按课程号从大到小排列

SELECT 课程号,成绩
FROM score
WHERE 成绩 < 60
ORDER BY 课程号 DESC;

10、查询每门课程的平均成绩,结果按平均成绩升序排序,平均成绩相同时,按课程号降序排列

SELECT 课程号,ROUND(AVG(成绩),2) AS 平均成绩
FROM score
GROUP BY 课程号
ORDER BY 平均成绩 ASC ,课程号 DESC;

11、检索课程编号为“0003”且分数小于60的学生学号,结果按按分数降序排列

SELECT 学号,成绩
FROM score
WHERE 课程号 = '0003' and 成绩 < 60;
ORDER BY 成绩  DESC;

该表为演示效果,将最后一行0003学号的成绩由80改为58

12、统计每门课程的学生选修人数(超过2人的课程才统计),要求输出课程号和选修人数,查询结果按人数降序排序,若人数相同,按课程号升序排序

SELECT 课程号,COUNT(学号) AS 选修人数
FROM score
GROUP BY 课程号
HAVING  COUNT(学号) > 2
ORDER BY 选修人数 DESC , 课程号 ASC;-- 升序是默认的,课程号后面的ASC可以不写

13、查询两门以上不及格课程的同学的学号及其平均成绩

SELECT 学号,AVG(成绩)  AS 平均成绩
FROM score
WHERE 成绩 < 60
GROUP BY 学号
HAVING  COUNT(课程号) >= 2;

该表为演示效果,将最后一行0003学号的成绩由80改为58

三、复杂查询习题练习

1、查询学生选修的所有课程成绩小于60分的学生的学号、姓名

SELECT 学号,姓名
FROM student
WHERE 学号 IN (
SELECT 学号
FROM score
GROUP BY 学号
HAVING MAX(成绩) < 60
);

该表为演示效果,score表有做修改

2、查询没有学全所有课的学生的学号、姓名

SELECT 学号,姓名
FROM student
WHERE 学号 IN (
SELECT 学号
FROM score
GROUP BY 学号
HAVING COUNT(学号) < (SELECT COUNT(课程号) FROM course)
);

3、查询出只选修了两门课程的全部学生的学号和姓名

SELECT 学号,姓名
FROM student
WHERE 学号 IN (
SELECT 学号
FROM score
GROUP BY 学号
HAVING COUNT(学号) =2
);

4、查询1990年出生的学生名单

SELECT 学号,姓名
FROM student
WHERE YEAR(出生日期) = '1990';


四、多表查询习题练习

1、查询所有学生的学号、姓名、选课、总成绩

SELECT a.学号,a.姓名,COUNT(b.课程号) AS 选课数,SUM(b.成绩) AS 总成绩
FROM student AS a LEFT JOIN score AS b
ON a.学号 = b.学号
GROUP BY a.学号;

2、查询平均成绩大于85的所有学生的学号、姓名和平均成绩

SELECT a.学号,a.姓名, ROUND(AVG(b.成绩),2) AS 平均成绩
FROM student AS a LEFT JOIN score AS b
ON a.学号 = b.学号
GROUP BY a.学号
HAVING AVG(b.成绩) > 85;

3、查询学生的选课情况:学号,姓名,课程号,课程名称

SELECT a.学号,a.姓名, b.课程号,c.课程名称
FROM student AS a INNER JOIN score AS b
ON a.学号 = b.学号
INNER JOIN course AS c
ON b.课程号 = c.课程号;

4、查询每门课程的及格人数和不及格人数

SELECT 课程号,
SUM(CASE
WHEN 成绩>=60
THEN 1
ELSE 0
END) AS 及格人数,
SUM(CASE
WHEN 成绩<60
THEN 1
ELSE 0
END ) AS 不及格人数
FROM score
GROUP BY 课程号;

5、使用分段[100-85]、[85-70]、[70-60],[<60]来统计各科成绩,分别统计:各分段人数,课程号和课程名称

SELECT a.课程号,b.课程名称,
SUM(CASE
WHEN 85< 成绩 AND 成绩 <= 100
THEN 1 ELSE 0 END) AS '[100-85]',
SUM(CASE
WHEN 70< 成绩 AND 成绩 <= 85
THEN 1 ELSE 0 END) AS '[85-70]',
SUM(CASE
WHEN 60<= 成绩 AND 成绩 <= 70
THEN 1 ELSE 0 END) AS '[70-60]',
SUM(CASE
WHEN 成绩 <60
THEN 1 ELSE 0 END) AS '[<60]'
FROM score AS a RIGHT JOIN course AS b
ON a.课程号 = b.课程号
GROUP BY a.课程号;

6、查询课编号为0003且课程成绩在80分以上的学生的学号、姓名和成绩

SELECT a.学号,a.姓名,b.成绩
FROM student AS a INNER JOIN score AS b
ON a.学号 = b.学号
WHERE b.课程号 = '0003' AND b.成绩 >80;

7、通过下图的查询结果,写出查询代码

参考代码为:

SELECT 学号,
MAX(CASE 课程号
WHEN '0001'
THEN 成绩 ELSE 0 END)
AS 课程号0001,
MAX(CASE 课程号
WHEN '0002'
THEN 成绩 ELSE 0 END)
AS 课程号0002,
MAX(CASE 课程号
WHEN  '0003'
THEN 成绩 ELSE 0 END)
AS 课程号0003
FROM score
GROUP BY 学号

复杂查询练习_MySQL基础知识—习题练习相关推荐

  1. 第一代电子计算机诞生的国家是( ),计算机基础知识习题.doc

    计算机基础知识习题.doc (2页) 本资源提供全文预览,点击全文预览即可全文预览,如果喜欢文档就下载吧,查找使用更方便哦! 9.90 积分 计算机基础知识题计算机的诞生:第一台电子计算机是1946 ...

  2. 微型计算机系统性能优化及测试,微型计算机系统测试、优化和升级基础知识习题...

    你很了解自己的电脑吗?想优化升级发挥自己电脑的性能吗?下载资料学习.实践一下吧 微型计算机系统测试.优化和升级基础知识习题 1. 简述计算机的主要性能指标. 答: (1)运算速度 运算速度是衡量计算机 ...

  3. 制作一个html文件 效果如下图,网页制作基础知识-习题课件.ppt

    网页制作基础知识-习题课件 第一章 网页制作基础知识;1.1 案例 网页制作学习园地网页;1.1案例:网页制作学习园地网页; 1.1.1 功能要求1.整个网站主要以HTML代码编写的方式完成.页面风格 ...

  4. 电子计算机的基本结构基于存储程序思想是由,第一章计算机基础知识习题

    <第一章计算机基础知识习题>由会员分享,可在线阅读,更多相关<第一章计算机基础知识习题(3页珍藏版)>请在人人文库网上搜索. 1.第一章 计算机基础知识习题一.单项选择题1.通 ...

  5. 2019计算机基础答案,2019年计算机基础知识习题与答案.doc

    PAGE PAGE 1 计算机基础知识习题与答案 选择题 一个完整的计算机系统应包括(A). A.硬件系统和软件系统 B.主机和外部设备 C.CPU和存储器 D.主机和实用程序 2.计算机系统中CPU ...

  6. html5哪个属性规定输入字段是必填的,HTML5基础知识习题及答案

    原标题:HTML5基础知识习题及答案 1. HTML5 之前的HTML版本是什么? 答: HTML 4.01 2. HTML5 的正确doctype是? 答: 3. 在 HTML5 中,哪个元素用于组 ...

  7. 计算机基础知识填空题及答案,计算机基础知识习题与答案(填空)

    计算机基础知识习题与答案 填空题 1.一个完整计算机系统应包括(硬件系统和软件系统) 2.计算机手统中CPU是指(运算器 ),它的小文名(存储器) 3.计算机性能主要取决于(字长.运算速度和内存地址) ...

  8. mysql的知识_mysql基础知识

    mysql基础知识 1. MySQL是一个小型关系型数据库管理系统 2. MySQL的数据类型: 整数型:TINYINT,SMALLINT,INT,BIGINT 小数型:FLOAT,DOUBLE,DE ...

  9. mysql注释符号_MySQL基础知识(2021最新版教程)

    一.MySQL简介 MySQL是一种开放源代码的关系型数据库管理系统,使用最常用的数据库管理语言--结构化查询语言(SQL)进行数据库管理. MySQL是开放源代码的,因此任何人都可以在General ...

最新文章

  1. ajax实现关联词提示
  2. 初次使用 Elasticsearch 遇多种分词难题?那是你没掌握这些原理
  3. 使用Android studio 运行react-native项目
  4. Jenkins自动化部署容器
  5. Centos下tomcat配置
  6. ServiceManager 进程启动源码分析
  7. python计数器Count
  8. php去掉文字空白换行,php去掉空格换行的方法
  9. 用什么计算机演奏音乐,用这个你可以用自己的电脑弹奏美妙的音乐.
  10. .CR2格式文件怎么快速批量转换成JPG等格式
  11. ae2018怎么打开2019_AE CC 2019新功能全面解析!
  12. cos和sin转换公式
  13. 点滴故事-写在我个人网站的0岁生日
  14. 一文看懂Android APK安装的原理
  15. python充电时刻
  16. HTML的样式及引入样式的三种类型
  17. whl is not a supported wheel on this platform.解决办法
  18. 【RMAN】RMAN跨版本恢复(中)
  19. oracle 命令操作
  20. 初级爬虫-获取网络图片

热门文章

  1. 在linux下的vsftp的使用
  2. FLASH与ASP.NET通讯[Flash | CS3 | ActionScript | ASP.NET | FluorineFx ]
  3. Linux 命令(4)—— declare/typeset 命令(builtin)
  4. vector向量容器元素排序与查找
  5. C++ 关于 main 函数的几点说明
  6. 转载:百集3D动画片《精灵世纪》制作揭密
  7. Python标准库--time模块的详解
  8. C# 读取word2003 并且显示在界面上的方法
  9. Python decorator
  10. 如果一切需要重学,2014年应该学哪些技术?