python/MySQL练习题(二)
python/MySQL练习题(二)
查询各科成绩前三名的记录:(不考虑成绩并列情况)
select score.sid,score.course_id,score.num,T.first_num,T.second_num from score left join
(
select
sid,
(select num from score as s2 where s2.course_id = s1.course_id order by num desc limit 0,1) as first_num,
(select num from score as s2 where s2.course_id = s1.course_id order by num desc limit 3,1) as second_num
from
score as s1
) as T
on score.sid =T.sid
where score.num <= T.first_num and score.num >= T.second_num
查询每门课程被选修的学生数
SELECT count(student_id) from score LEFT JOIN course on course.cid=score.course_id
GROUP BY course_id
HAVING COUNT(1) >4
查询出只选修了一门课程的全部学生的学号和姓名
SELECT student.sid,student.sname from score LEFT JOIN student on student.sid=score.student_id
LEFT JOIN course on course.cid=score.course_id
GROUP BY student_id
HAVING count(score.course_id)=''
查询男生、女生的人数
SELECT gender,count(sid) from student
GROUP BY gender
HAVING count(sid)
查询姓“张”的学生名单
SELECT * from student where sname like '张%'
查询同名同姓学生名单,并统计同名人数
SELECT sname,COUNT(sname) from student
GROUP BY sname
HAVING COUNT(sname)
查询每门课程的平均成绩,结果按平均成绩升序排列,平均成绩相同时,按课程号降序排列
SELECT course_id,avg(num) from score LEFT JOIN course on course.cid=score.course_id
GROUP BY course_id
ORDER BY avg(num) asc
查询平均成绩大于85的所有学生的学号、姓名和平均成绩
SELECT student.sid,student.sname,avg(num) from score LEFT JOIN student on student.sid=score.student_id
GROUP BY student_id
HAVING avg(num) > 85
查询课程名称为“物理”,且分数低于60的学生姓名和分数
SELECT student.sname,score.num from score LEFT JOIN student on student.sid=score.student_id
LEFT JOIN course on course.cid=score.course_id
where course.cname='生物' and score.num <60
查询课程编号为003且课程成绩在80分以上的学生的学号和姓名
SELECT student.sid,student.sname from score LEFT JOIN course on course.cid=score.course_id
LEFT JOIN student on student.sid=score.student_id
where course.cid='' and num > 80
求选了课程的学生人数
SELECT COUNT(c) from
(SELECT count(student_id)as c from score GROUP BY student_id)as A
查询选修“李平”老师所授课程的学生中,成绩最高的学生姓名及其成绩
SELECT sname,num from score
LEFT JOIN course on course.cid=score.course_id
LEFT JOIN student on student.sid=score.student_id
LEFT JOIN teacher on teacher.tid=course.teacher_id
where teacher.tname='李平老师'
GROUP BY student_id
ORDER BY num DESC
LIMIT 1
查询各个课程及相应的选修人数
SELECT cname,COUNT(1)from score LEFT JOIN course on course.cid=score.course_id
GROUP BY course_id
查询不同课程但成绩相同的学生的学号、课程号、学生成绩
select A1.student_id,A1.course_id,A2.course_id,A1.num,A2.num from score as A1 ,score as A2
where A1.course_id!=A2.course_id and A1.num=A2.num
GROUP BY student_id
查询每门课程成绩最好的前两名
select score.sid,score.course_id,score.num,T.first_num,T.second_num from score left join
(
select
sid,
(select num from score as s2 where s2.course_id = s1.course_id order by num desc limit 0,1) as first_num,
(select num from score as s2 where s2.course_id = s1.course_id order by num desc limit 1,1) as second_num
from
score as s1
) as T
on score.sid =T.sid
where score.num <= T.first_num and score.num >= T.second_num
检索至少选修两门课程的学生学号
-- SELECT count(A.c) from (select count(1)as c from score GROUP BY course_id)as A
SELECT student_id from score LEFT JOIN student on student.sid=score.student_id
GROUP BY student_id
HAVING count(1) > 2
查询全部学生都选修的课程的课程号和课程名
select course_id from score GROUP BY course_id HAVING COUNT(1)=(select count(1) from student)
查询没学过“李平”老师讲授的任一门课程的学生姓名
SELECT
student.sname
FROM
student
WHERE
sid NOT IN (
SELECT
course_id
FROM
score
LEFT JOIN course ON course.cid = score.course_id
LEFT JOIN student ON student.sid = score.student_id
LEFT JOIN teacher ON teacher.tid = course.teacher_id
WHERE
teacher.tname = '李平老师'
)
查询两门以上不及格课程的同学的学号及其平均成绩
SELECT student_id,avg(num) from score where num <60 GROUP BY student_id HAVING count(1)>2
检索“004”课程分数小于60,按分数降序排列的同学学号
SELECT student_id from score where course_id=4 and num <60 ORDER BY num DESC
删除“002”同学的“001”课程的成绩
DELETE from score where student_id=2 and course_id=1
python/MySQL练习题(二)的更多相关文章
- Python/ MySQL练习题(一)
Python/ MySQL练习题(一) 查询“生物”课程比“物理”课程成绩高的所有学生的学号 SELECT * FROM ( SELECT * FROM course LEFT JOIN score ...
- Python/MySQL(二、表操作以及连接)
Python/MySQL(二.表操作以及连接) mysql表操作: 主键:一个表只能有一个主键.主键可以由多列组成. 外键 :可以进行联合外键,操作. mysql> create table y ...
- python Mysql (二)
Mysql (二) 一. 事务 a.数据库开启事务命令 1 2 3 4 #start transaction 开启事务 #Rollback 回滚事务,即撤销指定的sql语句(只能回退insert de ...
- python 全栈开发,Day65(MySQL练习题,参考答案)
一.MySQL练习题 一.表关系 请创建如下表,并创建相关约束 二.操作表 1.自行创建测试数据 2.查询“生物”课程比“物理”课程成绩高的所有学生的学号.ps:针对的是自己的生物成绩比物理成绩高,再 ...
- python mysql redis mongodb selneium requests二次封装为什么大都是使用类的原因,一点见解
1.python mysql redis mongodb selneium requests举得这5个库里面的主要被用户使用的东西全都是面向对象的,包括requests.get函数是里面每次都是实例 ...
- Python之路-python(mysql介绍和安装、pymysql、ORM sqlachemy)
本节内容 1.数据库介绍 2.mysql管理 3.mysql数据类型 4.常用mysql命令 创建数据库 外键 增删改查表 5.事务 6.索引 7.python 操作mysql 8.ORM sqlac ...
- MySQL练习题
MySQL练习题 一.表关系 请创建如下表,并创建相关约束 二.操作表 1.自行创建测试数据 2.查询“生物”课程比“物理”课程成绩高的所有学生的学号: 3.查询平均成绩大于60分的同学的学号和平均成 ...
- Python Mysql 篇
Python 操作 Mysql 模块的安装 linux: yum install MySQL-python window: http://files.cnblogs.com/files/wupeiqi ...
- s15day12作业:MySQL练习题参考答案
MySQL练习题参考答案 导出现有数据库数据: mysqldump -u用户名 -p密码 数据库名称 >导出文件路径 # 结构+数据 mysqldump -u用户名 -p ...
随机推荐
- centos7上安装ELK
author:headsen chen data :2017-12-04 18:00:57 notice:created by chen himself and not allowed to cop ...
- python函数式编程之yield表达式形式
先来看一个例子 def foo(): print("starting...") while True: res = yield print("res:",res ...
- ReactNative环境配置的坑
我用的是windows开发android,mac的可以绕道了. 1.android studio及Android SDK的安装 现在需要的Android版本及对应的tool 2.真机运行要配置对and ...
- 微信小程序学习笔记(阶段二)
二阶段学习过程: (一)看官方文档的框架.组件.API:https://mp.weixin.qq.com/debug/wxadoc/dev/ (二)看极客学院第3.4章视频:http://www.ph ...
- [译文] SQL JOIN,你想知道的应该都有
介绍 这是一篇阐述SQL JOINs的文章. 背景 我是个不喜欢抽象的人,一图胜千言.我在网上查找了所有的关于SQL JOIN的解释,但是没有找到一篇能用图像形象描述的. 有些是有图片的但是他们没有覆 ...
- [iOS]详解调整UIButton的title和image的位置
UIButton的默认布局是:title在右,image在左; 很多时候我们需要的是title在左边,或者title在下面,这时就需要调整UIButton的TitleLabel和ImageView的位 ...
- Konckout第五个实例:各种事件绑定
点击加一: <!doctype html> <html > <head> <meta http-equiv="Content-Type" ...
- java开源安全框架-------Apache Shiro--第二天
身份验证 即在应用中谁能证明他就是他本人.一般提供如他们的身份ID一些标志信息来表明他就是他本人,如提供身份证.用户名.密码来证明 在shiro中,用户需要提供principals(身份)和crede ...
- Javascript中几个看起来简单,却不一定会做的题
Javascript作为前端开发必须掌握的一门语言,因为语言的灵活性,有些知识点看起来简单,在真正遇到的时候,却不一定会直接做出来,今天我们就一起来看看几道题目吧 题目1 var val = 'smt ...
- Oracle的用户,权限以及角色
一.用户 1.创建用户 创建用户u密码为aa. SQL> create user u identified by aa; 2.为用户赋予权限 这个用户还不能连接数据库,必须为其赋予一些权限才可以 ...