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 ...
随机推荐
- openstack的最简单安装
环境:采用centos7.4,最低4g内存.大硬盘.内存小了会在安装过程中报错.整个过程大概2小时,看网速快慢,所有的节点和服务都安装在同一台机器上. yum update -y yum inst ...
- Online Judge(OJ)搭建——2、数据库,SQL语句
数据库EER图 数据库表.字段.约束解释 users 用户: id 标识符,email 邮箱,password 密码,name 姓名,sex 性别,enabled 启用 ,role 角色 id pri ...
- EOS 开发进展速报
Daniel Larimer 刚刚披露了 EOS 的最近开发进展,原文 :https://steemit.com/eos/@dan/ukoxz-eos-io-development-update 为了 ...
- Java I/O 总结
Java I/O的的架构使用了装饰器的模式,我们在使用流的时候需要新建很多的装饰器对象,对源数据进行层层包装.各个包装类名以及它们的应用场景比较多,初学的时候难以摸清规律,这里我把它们归一下类,方便大 ...
- Java注解学习笔记
我们平常写Java代码,对其中的注解并不是很陌生,比如说写继承关系的时候经常用到@Override来修饰方法.但是@Override是用来做什么的,为什么写继承方法的时候要加上它,不加行不行.如果对J ...
- Markdown 语法手册 (完整整理版)
http://blog.csdn.net/witnessai1/article/details/52551362
- 深入解析C语言数组和指针
概述 指针是C语言的重点,同时也是让初学者认为最难理解的部分.有人说它是C语言的灵魂,只有深入理解指针才能说理解了C语言.暂且撇开这些观点不谈.这章是我在阅读<C和指针>这本书的读书笔记. ...
- [Scala] 实现 NDCG
一.关于 NDCG [LTR] 信息检索评价指标(RP/MAP/DCG/NDCG/RR/ERR) 二.代码实现 1.训练数据的加载解析 import scala.io.Source /* * 训练行数 ...
- beta冲刺用户测评-咸鱼
测评人:庄加鑫-咸鱼 测评结果 一.使用体验数据加载响应很快!页面切换丝滑流畅!UI有点偏暗,有些字被覆盖了.页面布局过于居中,两侧空白范围较大.总体功能完善.二.登录.注册.忘记密码界面管理员登录 ...
- Beta No.7
今天遇到的困难: 构造新适配器的时候出现了某些崩溃的问题 ListView监听器有部分的Bug 今天完成的任务: 陈甘霖:完成相机调用和图库功能,完成阿尔法项目遗留下来的位置调用问题,实现百度定位 蔡 ...