1、根据图创建下列表格

  没有外键的表先创建,创建顺序为teacher,class,course,student

CREATE TABLE class (
cid INT NOT NULL auto_increment PRIMARY KEY,
caption CHAR (32) NOT NULL
) ENGINE = INNODB DEFAULT charset = utf8; INSERT INTO score (caption)
VALUES
('三年二班'),
('一年三班'),
('三年一班') ;

2、查询“生物”课程比“物理”课程成绩高的所有学生的学号

CREATE VIEW vw1 AS SELECT
score.student_id AS "学号",
student.sname AS "姓名",
course.cname AS "科目",
number AS "生物分数"
FROM
score
LEFT JOIN course ON course.cid = score.course_id
LEFT JOIN student ON score.student_id = student.sid
WHERE
course.cname = '生物'; CREATE VIEW vw2 AS SELECT
score.student_id AS "学号",
student.sname AS "姓名",
course.cname AS "科目",
number AS "物理分数"
FROM
score
LEFT JOIN course ON course.cid = score.course_id
LEFT JOIN student ON score.student_id = student.sid
WHERE
course.cname = '物理'; SELECT
*
FROM
vw1
INNER JOIN vw2 ON vw1.学号 = vw2.学号
WHERE
vw1.生物分数 > vw2.物理分数;

3、查询平均成绩大于60分的同学的学号和平均成绩

SELECT
score.student_id AS "学号",
student.sname AS "姓名",
sum(score.number) AS "总分数",
avg(score.number) AS gva
FROM
score
LEFT JOIN course ON course.cid = score.course_id
LEFT JOIN student ON score.student_id = student.sid
GROUP BY
student_id
HAVING
gva > 60;

4、查询所有同学的学号、姓名、选课数、总成绩

SELECT
score.student_id AS "学号",
student.sname AS "姓名",
sum(score.number) AS "总成绩",
count(score.course_id) AS '课程数'
FROM
score
LEFT JOIN course ON course.cid = score.course_id
LEFT JOIN student ON score.student_id = student.sid
GROUP BY
student_id

5、查询姓“李”的老师的个数

SELECT
count(tname) AS "个数"
FROM
teacher
WHERE
tname LIKE "波%" ;

6、查询没学过“叶平”老师课的同学的学号、姓名

  思路:没学过某个老师,我可以找到学过这个老师的学生,并在学生表判断,排除这些学过的就是没学过了

    (学生学的课程id in (先找叶平老师教的课程id))

    最后只要排除 not in这群学生就可了

SELECT
*
FROM
student
WHERE
sid NOT IN (
SELECT DISTINCT
student_id
FROM
score
WHERE
course_id IN (
SELECT
cid
FROM
course
LEFT JOIN teacher ON teacher_id = tid
WHERE
tname = "波多"
)
)

7、查询学过“001”并且也学过编号“002”课程的同学的学号、姓名

  思路:先查出所有学了 001 或 002 的学生 course_id  in (001,002)

    然后group by  学生id,having进行科目数统计,等于2的就是符合条件的

SELECT
student_id,
sname
FROM
student
LEFT JOIN score ON student_id = student.sid
WHERE
course_id IN (1, 2)
GROUP BY
student_id
HAVING
count(student_id) = 2;

8、查询学过“叶平”老师所教的所有课的同学的学号、姓名

SELECT
*
FROM
student
WHERE
student.sid IN (
SELECT DISTINCT
student_id
FROM
score
WHERE
course_id IN (
SELECT
cid
FROM
course
LEFT JOIN teacher ON teacher.tid = course.teacher_id
WHERE
teacher.tname = '饭岛'
)
);

9、查询课程编号“002”的成绩比课程编号“001”课程低的所有同学的学号、姓名

SELECT
id1,
NAME
FROM
(
SELECT
student_id AS id1,
number AS number1,
student.sname AS NAME
FROM
score
LEFT JOIN student ON student.sid = score.student_id
WHERE
score.course_id = 1
) AS A
LEFT JOIN (
SELECT
student_id AS id2,
number AS number2
FROM
score
LEFT JOIN student ON student.sid = score.student_id
WHERE
score.course_id = 2
) AS B ON A.id1 = B.id2
WHERE
number1 > number2;

10、查询有课程成绩小于60分的同学的学号、姓名

SELECT DISTINCT
student.sid,
sname
FROM
student
LEFT JOIN score ON student.sid = score.student_id
WHERE
student.sid IN (
SELECT
student_id
FROM
score
WHERE
number < 60
);

11、查询没有学全所有课的同学的学号、姓名

SELECT
sid,
sname
FROM
student
WHERE
sid IN (
SELECT
student_id
FROM
score
GROUP BY
student_id
HAVING
count(student_id) = 3
);

12、查询至少有一门课与学号为“001”的同学所学相同的同学的学号和姓名

  思路:先找到001同学的course---一个元组

      course_id in 元组  ---student id元组

      sid in student id元组

SELECT DISTINCT
sid,
sname
FROM
student
WHERE
sid IN (
SELECT
student_id
FROM
score
WHERE
course_id IN (
SELECT
course_id
FROM
score
WHERE
student_id = 1
)
)
AND sid != 1;

13、查询至少学过学号为“001”同学所有课的其他同学学号和姓名

        先找到和001的学过的所有人

        然后个数 = 001所有学科     ==》 其他人可能选择的更多
SELECT
student.sid,
sname,
count(course_id)
FROM
score
LEFT JOIN student ON student.sid = score.student_id
WHERE
course_id IN (
SELECT
course_id
FROM
score
WHERE
student_id = 1
)
AND student_id != 1
GROUP BY
student_id
HAVING
count(student_id) = (
SELECT
count(course_id)
FROM
score
WHERE
student_id = 1
);

14、查询和“002”号的同学学习的课程完全相同的其他同学学号和姓名

  思路:总课程数=002课程总数  --》student_id集

     每位同学符合002同学学过课程的数目=002课程总数  》》student_id

     去两  --》交集

SELECT
student.sid,
sname,
count(course_id)
FROM
score
LEFT JOIN student ON student.sid = score.student_id
WHERE
student.sid IN (
SELECT
student_id
FROM
score
GROUP BY
student_id
HAVING
count(course_id) = (
SELECT
count(course_id)
FROM
score
WHERE
student_id = 2
)
)
AND course_id IN (
SELECT
course_id
FROM
score
WHERE
student_id = 2
)
AND student_id != 2
GROUP BY
student_id
HAVING
count(student_id) = (
SELECT
count(course_id)
FROM
score
WHERE
student_id = 2
);

15、删除学习“叶平”老师课的SC表记录

  思路:delete from  where 条件

    条件:老师--》》课程id_list-->>course_id in id_list

DELETE
FROM
score
WHERE
course_id in (
SELECT
cid
FROM
course
LEFT JOIN teacher ON teacher.tid = course.teacher_id
WHERE
tname = "苍空"
)

mysql练手的更多相关文章

  1. MySQL练手小试题

    创建表和数据 创建class表 create table class ( cid int(11) primary key auto_increment, caption varchar(32) not ...

  2. Python之路【第二十四篇】:Python学习路径及练手项目合集

      Python学习路径及练手项目合集 Wayne Shi· 2 个月前 参照:https://zhuanlan.zhihu.com/p/23561159 更多文章欢迎关注专栏:学习编程. 本系列Py ...

  3. Python入门、练手、视频资源汇总,拿走别客气!

    摘要:为方便朋友,重新整理汇总,内容包括长期必备.入门教程.练手项目.学习视频. 一.长期必备. 1. StackOverflow,是疑难解答.bug排除必备网站,任何编程问题请第一时间到此网站查找. ...

  4. 微信小程序初体验,入门练手项目--通讯录,后台是阿里云服务器(一)

    内容: 一.前言 二.相关概念 三.开始工作 四.启动项目起来 五.项目结构 六.设计理念 七.路由 八.部署线上后端服务 同步交流学习社区: https://www.mwcxs.top/page/4 ...

  5. 70个Python练手项目列表(都有完整教程)

    前言: 不管学习那门语言都希望能做出实际的东西来,这个实际的东西当然就是项目啦,不用多说大家都知道学编程语言一定要做项目才行. 这里整理了70个Python实战项目列表,都有完整且详细的教程,你可以从 ...

  6. 20个Java练手项目,献给嗜学如狂的人

    给大家推荐一条由浅入深的JAVA学习路径,首先完成 Java基础.JDK.JDBC.正则表达式等基础实验,然后进阶到 J2SE 和 SSH 框架学习.最后再通过有趣的练手项目进行巩固. JAVA基础 ...

  7. Java学习路径及练手项目合集

    Java 在编程语言排行榜中一直位列前排,可知 Java 语言的受欢迎程度了. 实验楼上的[Java 学习路径]中将首先完成 Java基础.JDK.JDBC.正则表达式等基础实验,然后进阶到 J2SE ...

  8. 练手mysqlbinlog日志恢复数据(centos6.5 64,mysql5.1)

    练手mysql bin log日志相关 系统是centos 6.5 64 阿里云的服务器 mysql版本5.1 1 如何开启bin-log日志? vi /etc/my.cnf [mysqld] log ...

  9. 10个相见恨晚的 Java 在线练手项目

    10个有意思的Java练手项目: 1.Java 开发简单的计算器 难度为一般,适合具有 Java 基础和 Swing 组件编程知识的用户学习 2.制作一个自己的 Java 编辑器 难度中等,适合 Ja ...

随机推荐

  1. linux crontab执行python脚本问题

    在工作中我们经常会写一个python脚本,然后想通过定时任务去执行,这时我们会想到crontab. 通过 crontab -e去设置crontab 例如:0     0       *       * ...

  2. Gherkin关键字

    Feature 功能 Background 背景 Scenario 场景 Outline Scenarios(or Examples) Given 假如.假设.假定 When 当 Then 那么 An ...

  3. linux socket读数据错误解释

    EINTR 表示某种阻塞的操作,被接收到的信号中断,造成的一种错误返回值. EAGAIN   从字面上来看,是提示再试一次.这个错误经常出现在当应用程序进行一些非阻塞(non-blocking)操作( ...

  4. HTML5事件-pageshow 和 pagehide

    <!doctype html> <html> <head> <title>html5事件</title> <meta charset= ...

  5. Python - pandas 数据分析

    pandas: powerful Python data analysis toolkit 官方文档: http://pandas.pydata.org/pandas-docs/stable/ 1. ...

  6. Echart - 最好最强大效果最丰富的可视化图表插件

    # 官网http://echarts.baidu.com/ # demohttp://echarts.baidu.com/gallery/index.html Echart npm install e ...

  7. 美团HD(9)-监听点击城市

    DJSelectCityViewController.h // 点击城市发出通知 - (void)tableView:(UITableView *)tableView didSelectRowAtIn ...

  8. HTML5学习笔记简明版(10):废弃的元素和属性

    废弃的元素(Element) 这个小节里列出的元素在HTML5里将不再使用.现有文档升级到 HTML5的话能够使用一些替代方案. 比如parser section 能够处理isindex 元素的功能. ...

  9. js与jquery实时监听输入框值的oninput与onpropertychange方法

    文实例讲述了js与jquery实时监听输入框值的oninput与onpropertychange方法.分享给大家供大家参考.具体如下: 最近做过一个项目,需求是下拉框里自动匹配关键字,具体细节是实时监 ...

  10. OpenCV学习笔记一:OpenCV概览与配置编译

    一,OpenCV OpenCV官方网站:http://opencv.org/  OpenCV目前最新代码库地址:https://github.com/itseez/opencv 二,简介: OpenC ...