mysql:如图:sql语句应该怎么查其中一门科目的最高分、最低分,平均得分等

武小凡 2018-01-05 08:32:28

如图:sql语句应该怎么根据其中的一个考试时间,查其中一门科目的总人数、评价差的人数和占比,评价中等的人数和占比,评价良好的人数和占比。最高分、最低分,平均得分,得分差。
还有就是怎么根据民族、年龄或者班级。然后根据其中的一个参考时间,查询每一个民族或者每一个年龄或者每一个班级的评价差的人数和占比,评价中等的人数和占比,评价良好的人数和占比。
...全文
1443 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
武小凡 2018-01-05
  • 打赏
  • 举报
回复
引用 3 楼 wuxiao_fan 的回复:
[quote=引用 1 楼 qq_38445797 的回复:] select count(1) as ALL, -- 总人数 (select count(1) from '学生考试表' as a left join '学生表' as b on a.学生ID=b.idwhere a.考试时间='期中考试' WHERE 评价='差') AS badboy, -- 差的人数 badboy/ALL as percent -- 百分比 from '学生考试表' as a left join '学生表' as b on a.学生ID=b.id where a.考试时间='期中考试';
这里只有差的人数和百分比。那中等的和优秀的人数和百分比,最高分、最低分,平均分和得分差。这个该怎么写啊? 还有就是,按照民族或者班级或者年龄。去查其中一个考试时间的各个评价的人数和百分比。 [/quote] 我比较菜
qq_38445797 2018-01-05
  • 打赏
  • 举报
回复
你要明白你查的东西需要做几步,分开做就好了
qq_38445797 2018-01-05
  • 打赏
  • 举报
回复
select * from '学生考试表' as a left join '学生表' as b on a.学生ID=b.id -- 查询全部。 select count(1) as ALL, -- 总人数 (select count(1) from '学生考试表' as a left join '学生表' as b on a.学生ID=b.idwhere a.考试时间='期中考试' WHERE 评价='差') AS badboy, -- 差的人数 badboy/ALL as percent, -- 差的人数的百分比 (select count(1) from '学生考试表' as a left join '学生表' as b on a.学生ID=b.idwhere a.考试时间='期中考试' WHERE 评价='中等') AS middleboy, -- 中等人数 middleboy/ALL as percent, -- 中等人数百分比 (select count(1) from '学生考试表' as a left join '学生表' as b on a.学生ID=b.idwhere a.考试时间='期中考试' WHERE 评价='优秀') AS goodboy, -- 差的人数 goodboy/ALL as percent, -- 优秀人数的百分比 MAX(a.成绩) as maxscore, -- 最高分 MIN(a.成绩) as minscore, -- 最低分 AVG(a.成绩) as avgscore -- 平均分 from '学生考试表' as a left join '学生表' as b on a.学生ID=b.id where a.考试时间='期中考试'; 这不都是一样的吗。。。你要查啥就加一行就是了啊。
武小凡 2018-01-05
  • 打赏
  • 举报
回复
引用 1 楼 qq_38445797 的回复:
select count(1) as ALL, -- 总人数 (select count(1) from '学生考试表' as a left join '学生表' as b on a.学生ID=b.idwhere a.考试时间='期中考试' WHERE 评价='差') AS badboy, -- 差的人数 badboy/ALL as percent -- 百分比 from '学生考试表' as a left join '学生表' as b on a.学生ID=b.id where a.考试时间='期中考试';
这里只有差的人数和百分比。那中等的和优秀的人数和百分比,最高分、最低分,平均分和得分差。这个该怎么写啊? 还有就是,按照民族或者班级或者年龄。去查其中一个考试时间的各个评价的人数和百分比。
qq_38445797 2018-01-05
  • 打赏
  • 举报
回复
表就不要用汉字了吧。。
qq_38445797 2018-01-05
  • 打赏
  • 举报
回复
select count(1) as ALL, -- 总人数 (select count(1) from '学生考试表' as a left join '学生表' as b on a.学生ID=b.idwhere a.考试时间='期中考试' WHERE 评价='差') AS badboy, -- 差的人数 badboy/ALL as percent -- 百分比 from '学生考试表' as a left join '学生表' as b on a.学生ID=b.id where a.考试时间='期中考试';
此为吉林大学数据库的实验报告,实验内容为: 实验一 熟悉MySQL环境及SQL定义语言 一、实验目的: 1. 了解MySQL程序构成、安装、管理方法。 2. 了解MySQL数据库及表结构。 3. 熟练掌握SQL语言进行基本表结构的创建。 4. 熟练应用SQL语言进行表结构的修改。 5. 掌握SQL语言进行基本表的删除。 6. 掌握SQL语言进行索引的建立和删除。 二、实验内容和主要步骤: 1. 参考“MYSQL简体中文参考文档.chm”,熟悉MySQL构成和功能特性。 2. 打开Windows服务管理器,实验启动、停止MySQL服务,了解MySQL的服务管理方法; 3. 打开“MySQL管理控制台.bat”,熟悉控制台中操作数据库; 4. 利用控制台创建“Student数据库”。 5. 打开“Student”数据库,创建如下三个表,按下面的列表中的字段名(英文)、类型和宽度建立: 7. 用SQL语言CREATE TABLE语句创建学生表student、课程表course和选课表SC;(字段类型及长度参照实验一) 8. 用SQL语言ALTER语句修改表结构; a) STUDENT表中SNO设为非空和唯一; b) STUDENT表中增加一个字段SBIRTH,类型设置为日期时间类型,增加一个ADDRESS字段,类型为文本(字符); c) 删除STUDENT表中ADDRESS字段; d) COURSE表中CNO字段设为非空和唯一; 9. 重新定义一个简单表,然后用SQL语言DROP语句删除该表结构; 10. 用SQL语言CREATE INDEX语句定义表STUDENT的SNAME字段的降序索引; 11. 用SQL语言CREATE INDEX语句定义表SC的GRADE字段的升序索引; 12. 用SQL语言DROP语句删除索引; 13. 输入部数据,并试着修改其中的错误; 注: 实验二 SQL语言进行简单询 一、实验目的: 1. 掌握SQL询语句的一般格式 2. 掌握简单数据询操作。 3. 熟练掌握各种询条件的表示。 4. 掌握排序和组操作在SQL语句中的实现。 5. 掌握集函数的使用。 二、实验内容和主要步骤: 1. 创建学生表student、课程表course和选课表SC,并输入数据(注意数据的完整性。);(可以使用实验一中已经建立的表和数据) 2. 对各表中的数据进行不同条件的询; 1) 询全体学生的学号和姓名 2) 询全体学生的详细记录 3) 询所有选修过课程的学生学号 4) 询考试有不及格的学生学号 5) 询不是信息系(IS)、计算机系(CS)的学生性别、年龄、系别 6) 询选修了4号课的学生学号和成绩,结果按成绩降序排列 7) 询每个课程号和相应的选课人数 8) 询计算机系(CS)的学生姓名、年龄、系别 9) 询年龄18-20岁的学生学号、姓名、系别、年龄; 10) 询姓刘的学生情况 11) 询既选修1号课程,又选修2号课程的学生学号 12) 询学生的姓名和出生年份(今年2003年) 13) 询没有成绩的学生学号和课程号 14) 询总成绩大于200的学生学号 15) 询每门课程不及格学生人数 16) 询不及格课程超过3门的学生学号 17) 询年龄在10到19岁之间的学生信息 18) 询全体学生情况,按所在系升序排列,同一个系的学生按年龄降序排列 19) 询选了1号课程的学生平均成绩 20) 询选了3号课程的学生的最高 21) 询每个同学的总成绩 实验三 SQL进行复杂询 一、实验目的: 1. 熟练掌握各种连接询及其连接条件。 2. 掌握各种嵌套询的使用。 3. 掌握复杂的集合询。 二、内容和主要步骤: 1.实验一中的数据为基础 2.对各表中的数据进行不同条件的连接询和嵌套询; 1) 询每个学生及其选课情况; 2) 询每门课的间接先修课 3) 将STUDENT,SC进行右连接 4) 询有不及格的学生姓名和所在系 5) 询所有成绩为优秀(大于90)的学生姓名 6) 询既选修了2号课程又选修了3号课程的学生姓名、学号; 7) 询和刘晨同一年龄的学生 8) 选修了课程名为“数据库”的学生姓名和年龄 9) 询其他系比IS系任一学生年龄小的学生名单 10) 询其他系中比IS系所有学生年龄都小的学生名单 11) 询选修了全部课程的学生姓名 12) 询计算机系学生及其性别是男的学生 13) 询选修课程1的学生集合和选修2号课程学生集合的差集 14) 询李丽同学不学的课程的课程号 15) 询选修了3号课程的学生平均年龄 16) 求每门课程学生的平均成绩 17) 统计每门课程的学生选修人数(超过3人的才统计)。要求输出课程号和选修人数,结果按人数降序排列,若人数相同,按课程号升序排列 18) 询学号比刘晨大,而年龄比他小的学生姓名。 19) 求年龄大于女同学平均年龄的男同学姓名和年龄 20) 求年龄大于所有女同学年龄的男同学姓名和年龄 21) 询至少选修了95002选修的全部课程的学生号码 22) 询95001和95002两个学生都选修的课程的信息 实验四 SQL的常用数据更新操作 一、实验目的: 1. 熟练掌握SQL的常用数据更新操作。 2. 熟练应用INSERT,UPDATE,DELETE语句。 3. 掌握更新操作的各种格式。 二、实验内容和主要步骤 1. 应用INSERT,UPDATE,DELETE语句进行更新操作; 1) 插入如下学生记录(学号:95030,姓名:李莉,年龄:18) 2) 插入如下选课记录(95030,1) 3) 计算机系学生年龄改成20 4) 数学系所有学生成绩改成0 5) 把低于总平均成绩的女同学成绩提高5 6) 修改2号课程的成绩,若成绩小于75提高5%,成绩大于75时提高 7) 4%(两个语句实现,注意顺序) 8) 删除95030学生信息 9) 删除SC表中无成绩的记录 10) 删除张娜的选课记录 11) 删除数学系所有学生选课记录 12) 删除不及格的学生选课记录 13) 询每一门课程成绩都大于等于80的学生学号、姓名和性别,把值送往另一个已经存在的基本表STU(SNO,SNAME,SSEX)中 14) 把所有学生学号和课程号连接追加到新表中 15) 所有学生年龄增1 16) 统计3门以上课程不及格的学生把相应的学生姓名、系别追加到另外一个表中 2.熟练掌握INSERT,UPDATE,DELETE语句并能综合应用;

51,411

社区成员

发帖
与我相关
我的任务
社区描述
Java相关技术讨论
javaspring bootspring cloud 技术论坛(原bbs)
社区管理员
  • Java相关社区
  • 小虚竹
  • 谙忆
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧