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练习题(二)的更多相关文章

  1. Python/ MySQL练习题(一)

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

  2. Python/MySQL(二、表操作以及连接)

    Python/MySQL(二.表操作以及连接) mysql表操作: 主键:一个表只能有一个主键.主键可以由多列组成. 外键 :可以进行联合外键,操作. mysql> create table y ...

  3. python Mysql (二)

    Mysql (二) 一. 事务 a.数据库开启事务命令 1 2 3 4 #start transaction 开启事务 #Rollback 回滚事务,即撤销指定的sql语句(只能回退insert de ...

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

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

  5. python mysql redis mongodb selneium requests二次封装为什么大都是使用类的原因,一点见解

    1.python mysql  redis mongodb selneium requests举得这5个库里面的主要被用户使用的东西全都是面向对象的,包括requests.get函数是里面每次都是实例 ...

  6. Python之路-python(mysql介绍和安装、pymysql、ORM sqlachemy)

    本节内容 1.数据库介绍 2.mysql管理 3.mysql数据类型 4.常用mysql命令 创建数据库 外键 增删改查表 5.事务 6.索引 7.python 操作mysql 8.ORM sqlac ...

  7. MySQL练习题

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

  8. Python Mysql 篇

    Python 操作 Mysql 模块的安装 linux: yum install MySQL-python window: http://files.cnblogs.com/files/wupeiqi ...

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

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

随机推荐

  1. Y2K问题

    关于第五章 团队和流程 2.6 特工团队中所提到的Y2K问题,第一次接触到这个名词去百度了,它的意思是这样的:year 2K problem,又称千年虫问题.主要原因是早期的软件大多以两位数字来记录年 ...

  2. Keeweb-Linux的密码管理器

    Keeweb-Linux的密码管理器 如今,我们依赖于越来越多的线上服务.我们每注册一个线上服务,就要设置一个密码:如此,我们就不得不记住数以百计的密码.这样对于每个人来说,都很容易忘记密码.那么,下 ...

  3. 读取pdf内容分页和全部

    //读取pdf 全部内容public static String topdffile(String pdffile){ StringBuffer result = new StringBuffer() ...

  4. 用JAVA进行Json数据解析(对象数组的相互嵌套)

    这段时间我们在做一个英语翻译软件的小小小APP,涉及到了对Json数据的解析,所以特地来总结一下! 假设我们要对如下数据进行解析,其实在平时,返回的Json数据是很乱的,很难分清数据的关系,这是经过相 ...

  5. java判断用户输入的是否至少含有N位小数

    判断用户输入的是否至少含有N位小数. 1.当用户输入的是非数字时抛出异常,返回false. 2.当用户输入数字是,判断其数字是否至少含有N位小数,如果不含有,返回false. 3.当用户输入的数字的小 ...

  6. Mycat 介绍

    Mycat 是什么 Mycat是什么?从定义和分类来看,它是一个开源的分布式数据库系统,是一个实现了 MySQL协议的的Server,前端用户可以把它看作是一个数据库代理,用 MySQL客户端工具和命 ...

  7. 设计模式 --> (17)状态模式

    状态模式 允许一个对象在其内部状态改变时改变它的行为.对象看起来似乎修改了它的类.它有两种使用情况: (1)一个对象的行为取决于它的状态, 并且它必须在运行时刻根据状态改变它的行为. (2)一个操作中 ...

  8. Java基础学习笔记五 Java基础语法之面向对象

    面向对象 理解什么是面向过程.面向对象 面向过程与面向对象都是我们编程中,编写程序的一种思维方式.面向过程的程序设计方式,是遇到一件事时,思考“我该怎么做”,然后一步步实现的过程.例如:公司打扫卫生( ...

  9. @Cacheable的实现原理

    如果你用过Spring Cache,你一定对这种配置和代码不陌生: <cache:annotation-driven cache-manager="cacheManager" ...

  10. alpha-咸鱼冲刺day4

    一,合照 emmmmm.自然还是没有的. 二,项目燃尽图 三,项目进展 QAQ具体工作量没啥进展.但是前后端终于可以数据交互了!.. 四,问题困难 日常啥都不会,百度真心玩一年. 还得自学nodejs ...