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 ...
随机推荐
- 怎样使用yum安装OpenStack
怎样使用yum安装OpenStack headsen chen 2017-10-09 19:17:15 个人原创博客,转载请注明作者,出处,否则追究法律责任 [sh ...
- Centos虚拟机克隆模板
Centos6模板 IPTABLES/SELINUX # iptalbes -F # service iptables save 或 # /etc/init.d/iptables stop # chk ...
- Ubuntu下sudo命令出现无法解析主机名
替换hosts文件后sudo命令提示 无法解析主机名 把hosts文件中127.0.0.1后的名字改为主机名,即 /etc/hostname 中的名字
- phpStorm安装方法
1)下载 http://big2.h5gamen.com/soft/jetbrainscrack-2.6.2.zip 放到phpstorm安装目录下的lib文件夹 如放到f盘 F:\PhpStorm ...
- python为运维人员打造一个监控脚本
0x00前言: 一直想写一个监控方面的脚本,然后想到了运维这方面的 后来就写了个脚本. 0x001准备: psutil模块 0x02正文: import os import time import r ...
- 笔记:XML-解析文档-DOM
要处理XML文档,就要先解析(parse)他,解析器时这样一个程序,读入一个文件,确认整个文件具有正确的格式,然后将其分解成各种元素,使得程序员能够访问这些元素,Java库提供了两种XML解析器: 像 ...
- 2.java.util.logging.Logger使用详解
一.java.util.logging.Logger简介 java.util.logging.Logger不是什么新鲜东西了,1.4就有了,可是因为log4j的存在,这个logger一直沉默着, 其实 ...
- JAVA NIO之文件通道
1.简介 通道是 Java NIO 的核心内容之一,在使用上,通道需和缓存类(ByteBuffer)配合完成读写等操作.与传统的流式 IO 中数据单向流动不同,通道中的数据可以双向流动.通道既可以读, ...
- 从 MVC 到前后端分离
从 MVC 到前后端分离 1 理解 MVC MVC 是一种经典的设计模式,全名为 Model-View-Controller,即 模型-视图-控制器. 其中,模型 是用于封装数据的载体,例如,在 Ja ...
- 使用Docker快速搭建Nginx+PHP-FPM环境
下载nginx官方镜像和php-fpm镜像 docker pull nginx docker pull bitnami/php-fpm 使用php-fpm镜像开启php-fpm应用容器 docker ...