MySQL 查询word

张开发
2026/4/20 22:10:18 15 分钟阅读
MySQL 查询word
一、首先要登录到MySQL创建cdwl_emt(成都文理学院教务管理数据表)进入到该数据库中二、创建表格1.学生表Student(SId,Sname,Sage,Ssex)--SId 学生编号,Sname 学生姓名,Sage 出生年月,Ssex 学生性别2.教师表Teacher(TId,Tname)--TId 教师编号,Tname 教师姓名3.课程表Course(CId,Cname,TId)--CId 课程编号,Cname 课程名称,TId 教师编号4.成绩表SC(SId,CId,score)--SId 学生编号,CId 课程编号,score 分数三、插入数据1、学生表2、教师表3、科目表4、成绩表练习题目1.查询 01 课程比 02 课程成绩高的学生的信息及课程分数1.1 查询同时存在 01 课程和 02 课程的情况1.2 查询存在 01 课程但可能不存在 02 课程的情况(不存在时显示为 null )先查存在01课程的再查有02课程的再用左连接LEFT JOIN:左表全留右表匹配不上显示NULL1.3 查询不存在 01 课程但存在 02 课程的情况先查存在02课程再通过and连接不存在01课程的情况AND表示两个都要满足才成立2.查询平均成绩大于等于 60 分的同学的学生编号和学生姓名和平均成绩先将Student跟SC表用inner join关联内连接用学生编号进行分组group by然后用having限定平均成绩大于60的条件3.查询在 SC 表存在成绩的学生信息查询学生表因为每个学生有的有几门课程就会重复所以利用distinct去重4.查询所有同学的学生编号、学生姓名、选课总数、所有课程的总成绩(没成绩的显示为 null )4.1 查有成绩的学生信息5.查询「李」姓老师的数量6.查询学过「张三」老师授课的同学的信息7.查询没有学全所有课程的同学的信息先算出有全部课程的同学再除掉就可以得到没有学生所有课程的同学的信息了8.查询至少有一门课与学号为 01 的同学所学相同的同学的信息9.查询和 01 号的同学学习的课程完全相同的其他同学的信息10.查询没学过张三老师讲授的任一门课程的学生姓名11.查询两门及其以上不及格课程的同学的学号姓名及其平均成绩12.检索 01 课程分数小于 60按分数降序排列的学生信息13.按平均成绩从高到低显示所有学生的所有课程的成绩以及平均成绩14.查询各科成绩最高分、最低分和平均分以如下形式显示课程 ID课程 name最高分最低分平均分及格率中等率优良率优秀率及格为60中等为70-80优良为80-90优秀为90要求输出课程号和选修人数查询结果按人数降序排列若人数相同按课程号升序排列15.按各科成绩进行排序并显示排名 Score 重复时保留名次空缺15.1 按各科成绩进行排序并显示排名 Score 重复时合并名次16.查询学生的总成绩并进行排名总分重复时保留名次空缺16.1 查询学生的总成绩并进行排名总分重复时不保留名次空缺17.统计各科成绩各分数段人数课程编号课程名称[100-85][85-70][70-60][60-0] 及所占百分比18.查询各科成绩前三名的记录19.查询每门课程被选修的学生数20.查询出只选修两门课程的学生学号和姓名21.查询男生、女生人数22.查询名字中含有「风」字的学生信息SELECT * FROM Student WHERE Sname LIKE %风%;23.查询同名同性学生名单并统计同名人数24.查询 1990 年出生的学生名单25.查询每门课程的平均成绩结果按平均成绩降序排列平均成绩相同时按课程编号升序排列26.查询平均成绩大于等于 85 的所有学生的学号、姓名和平均成绩select s.SId, s.sname, AVG(sc.score) as avg_sal from student as s, scwhere s.SId sc.SIdgroup by sc.SIdHAVING avg_sal 85;27.查询课程名称为「数学」且分数低于 60 的学生姓名和分数28.查询所有学生的课程及分数情况存在学生没成绩没选课的情况29.查询任何一门课程成绩在 70 分以上的姓名、课程名称和分数30.查询不及格的课程31.查询课程编号为 01 且课程成绩在 80 分以上的学生的学号和姓名32.求每门课程的学生人数33.成绩不重复查询选修「张三」老师所授课程的学生中成绩最高的学生信息及其成绩35.查询不同课程成绩相同的学生的学生编号、课程编号、学生成绩36.查询每门功成绩最好的前两名37.统计每门课程的学生选修人数超过 5 人的课程才统计38.检索至少选修两门课程的学生学号39.查询选修了全部课程的学生信息40.查询各学生的年龄只按年份来算41.按照出生日期来算当前月日 出生年月的月日则年龄减一42.查询本周过生日的学生43.查询下周过生日的学生44.查询本月过生日的学生45.查询下月过生日的学生

更多文章