1、数据库是按照原文制作的,表格结构一样具体存储的数据有些差异

原文地址:MySQL练习题

原答案地址:MySQL练习题参考答案

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

select wl.sid from (select sc.student_id as sid,sc.number as grade from score sc,course c
where c.cid=sc.course_id and c.cname='物理') as wl,(select sc.student_id as sid,sc.number as

grade from score sc,course c where c.cid=sc.course_id and c.cname='生物') as sw where

wl.sid=sw.sid and sw.grade>wl.grade;

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

select student_id,avg(number) as avg from score group by student_id having avg(number)>60;

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

select s.sid,s.sname,w.total,w.sum from student s,(select student_id,count(course_id) as

total,sum(number) as sum from score group by student_id) as w where s.sid=w.student_id;

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

select count(*) from teacher where tname like '钱%';

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

select s.sid,s.sname from student as s where s.sid not in (select distinct sc.student_id from

score as sc,teacher as t,course as c where t.tid=c.teacher_id and c.cid=sc.course_id and

t.tname='赵');

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

select student.sid,student.sname from student,(select * from score where course_id=1) as w,

(select * from score where course_id=2) as e where w.student_id=e.student_id and

student.sid=w.student_id;

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

select s.sid,s.sname from student as s where s.sid in (select distinct sc.student_id from

score as sc,teacher as t,course as c where t.tid=c.teacher_id and c.cid=sc.course_id and

t.tname='赵');

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

select student.sid as id,student.sname as name from student,(select w.student_id as wid from

(select * from score where course_id=1) as w,(select * from score where course_id=2) as e

where w.student_id=e.student_id and w.number>e.number) as m where m.wid=student.sid;

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

select s.sid as id,s.sname as name from student as s,score as sc where s.sid=sc.student_id

and sc.number<60 group by s.sid;

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

select sid,sname from student where sid in (select distinct student_id from score group by

student_id having count(course_id)=(select count(*) from course));

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

select sid,sname from (select distinct student_id from score left join (select course_id from

score left join student on score.student_id = student.sid where student.sid=1) as c on

score.course_id = c.course_id where student_id != 1) s left join student on

s.student_id=student.sid;

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

select student.sid,student.sname from student right join score on

student.sid=score.student_id where student_id!=1 and course_id in (select course_id from

score where student_id=1) group by student_id having count(course_id)=(select count

(course_id) from score where student_id=1);

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

select sid,sname from student where sid in (select student_id from score right join (select

course_id from score where student_id=1) w on score.course_id=w.course_id where student_id!=1

group by student_id having count(student_id)=(select count(*) from score where

student_id=1));

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

delete from score where course_id in (select cid from teacher,course where

teacher.tid=course.teacher_id and teacher.tname='周');

16、向SC表中插入一些记录,这些记录要求符合以下条件:①没有上过编号“002”课程的同学学号;②插入“002”号课程的平均成绩;

insert into score(student_id,course_id,number) select sid,1,(select avg(number) from score

where course_id=1) from student where sid not in (select student_id from score where

course_id=1);

未完待续

mysql练习题练习的更多相关文章

  1. MySQL练习题

    MySQL练习题 一.表关系 请创建如下表,并创建相关约束 二.操作表 1.自行创建测试数据 2.查询“生物”课程比“物理”课程成绩高的所有学生的学号: 3.查询平均成绩大于60分的同学的学号和平均成 ...

  2. MySQL练习题参考答案

    MySQL练习题参考答案 2.查询“生物”课程比“物理”课程成绩高的所有学生的学号: 思路: 获取所有有生物课程的人(学号,成绩) - 临时表 获取所有有物理课程的人(学号,成绩) - 临时表 根据[ ...

  3. s15day12作业:MySQL练习题参考答案

    MySQL练习题参考答案   导出现有数据库数据: mysqldump -u用户名 -p密码 数据库名称 >导出文件路径           # 结构+数据 mysqldump -u用户名 -p ...

  4. Python/ MySQL练习题(一)

    Python/ MySQL练习题(一) 查询“生物”课程比“物理”课程成绩高的所有学生的学号 SELECT * FROM ( SELECT * FROM course LEFT JOIN score ...

  5. python/MySQL练习题(二)

    python/MySQL练习题(二) 查询各科成绩前三名的记录:(不考虑成绩并列情况) select score.sid,score.course_id,score.num,T.first_num,T ...

  6. python 全栈开发,Day65(MySQL练习题,参考答案)

    一.MySQL练习题 一.表关系 请创建如下表,并创建相关约束 二.操作表 1.自行创建测试数据 2.查询“生物”课程比“物理”课程成绩高的所有学生的学号.ps:针对的是自己的生物成绩比物理成绩高,再 ...

  7. mysql 练习题答案

    一 题目 1.查询所有的课程的名称以及对应的任课老师姓名 2.查询学生表中男女生各有多少人 3.查询物理成绩等于100的学生的姓名 4.查询平均成绩大于八十分的同学的姓名和平均成绩 5.查询所有学生的 ...

  8. MySQL练习题及答案(复习)

    新建一个叫做 review 的数据库,将测试数据脚本导进去.(可以使用Navicat查询功能) /* Navicat MySQL Data Transfer Source Server : DB So ...

  9. mysql练习题-查询同时参加计算机和英语考试的学生的信息-遁地龙卷风

    (-1)写在前面 文章参考http://blog.sina.com.cn/willcaty. 针对其中的一道练习题想出两种其他的答案,希望网友给出更多回答. (0) 基础数据 student表 +-- ...

随机推荐

  1. Jquery ajax 与 lazyload的混合使用(实现图片异步加载)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...

  2. hibernate课程 初探单表映射1-1 第一章

    本章内容: 1 什么是orm 2 hibernate简介 3 编写第一个hibernate小例子

  3. HhashMap HashTable ConcurrentHashMap

    hashMap hashTable concurrentHashMap hashMap的效率高于hashTable,hashMap是线程不安全的,并发时hashMap put方法容易引起死循环,导致c ...

  4. [Unity3D] 如何识别屏幕边缘

    出现的问题 Unity3D中长度单位是米 使用Screen.resolutions获取的屏幕信息单位是像素 也就是说,即使获取了屏幕相关信息及参数,也无法把信息转换成可在editor中使用的信息.当时 ...

  5. 使用C#版OpenCV进行圆心求取

    OpenCVSharp是OpenCV的.NET wrapper,是一名日本工程师开发的,项目地址为:https://github.com/shimat/opencvsharp. 该源码是 BSD开放协 ...

  6. uvm_tlm_if_base——TLM1事务级建模方法(三)

    文件: src/tlm1/uvm_tlm_ifs.svh 类: uvm_tlm_if_base 这个类没有派生自任何类,在类的中,定义了三类接口:第一类是阻塞性质的普通方法(task),put, ge ...

  7. [论文理解]MetaAnchor: Learning to Detect Objects with Customized Anchors

    MetaAnchor: Learning to Detect Objects with Customized Anchors Intro 本文我其实看了几遍也没看懂,看了meta以为是一个很高大上的东 ...

  8. vs2015“当前不会命中断点 还没有为该文档加载任何符号”的解决方法

    解决方法:工具-选项-调试 -(启用“仅我的代码”)勾去掉

  9. Echarts样式

    Echarts设置样式如下 <div id="main" style="width: 250px;height:200px;"></div&g ...

  10. .NET中变量生存期

    Web窗体后台 cs 文件中,创建类作用域的变量,在关闭页面的时候并不会消失,当 IIS 站点被关闭的时候,才会调用这个变量的析构函数 但是好像也不肯定在关闭站点才会析构,应该是外层对象析构的时候才会 ...