概述
题目和表结构都是在网上找的 只有sql是自己写的 如果有欠缺和可以优化的地方希望可以直接指出来 这也是一种学习方式。
表+数据
--建表
--学生表
CREATE TABLE `student`(
`s_id` VARCHAR(20),
`s_name` VARCHAR(20) NOT NULL DEFAULT '',
`s_birth` VARCHAR(20) NOT NULL DEFAULT '',
`s_sex` VARCHAR(10) NOT NULL DEFAULT '',
PRIMARY KEY(`s_id`)
);
--课程表
CREATE TABLE `course`(
`c_id` VARCHAR(20),
`c_name` VARCHAR(20) NOT NULL DEFAULT '',
`t_id` VARCHAR(20) NOT NULL,
PRIMARY KEY(`c_id`)
);
--教师表
CREATE TABLE `teacher`(
`t_id` VARCHAR(20),
`t_name` VARCHAR(20) NOT NULL DEFAULT '',
PRIMARY KEY(`t_id`)
);
--成绩表
CREATE TABLE `score`(
`s_id` VARCHAR(20),
`c_id` VARCHAR(20),
`c_score` INT(3),
PRIMARY KEY(`s_id`,`c_id`)
);
--插入学生表测试数据
insert into student values('01' , '赵雷' , '1990-01-01' , '男');
insert into student values('02' , '钱电' , '1990-12-21' , '男');
insert into student values('03' , '孙风' , '1990-05-20' , '男');
insert into student values('04' , '李云' , '1990-08-06' , '男');
insert into student values('05' , '周梅' , '1991-12-01' , '女');
insert into student values('06' , '吴兰' , '1992-03-01' , '女');
insert into student values('07' , '郑竹' , '1989-07-01' , '女');
insert into student values('08' , '王菊' , '1990-01-20' , '女');
--课程表测试数据
insert into course values('01' , '语文' , '02');
insert into course values('02' , '数学' , '01');
insert into course values('03' , '英语' , '03');
--教师表测试数据
insert into teacher values('01' , '张三');
insert into teacher values('02' , '李四');
insert into teacher values('03' , '王五');
--成绩表测试数据
insert into score values('01' , '01' , 80);
insert into score values('01' , '02' , 90);
insert into score values('01' , '03' , 99);
insert into score values('02' , '01' , 70);
insert into score values('02' , '02' , 60);
insert into score values('02' , '03' , 80);
insert into score values('03' , '01' , 80);
insert into score values('03' , '02' , 80);
insert into score values('03' , '03' , 80);
insert into score values('04' , '01' , 50);
insert into score values('04' , '02' , 30);
insert into score values('04' , '03' , 20);
insert into score values('05' , '01' , 76);
insert into score values('05' , '02' , 87);
insert into score values('06' , '01' , 31);
insert into score values('06' , '03' , 34);
insert into score values('07' , '02' , 89);
insert into score values('07' , '03' , 98);
题目
-- 1、查询"01"课程比"02"课程成绩高的学生的信息及课程分数
-- 2、查询"01"课程比"02"课程成绩低的学生的信息及课程分数
-- 3、查询平均成绩大于等于60分的同学的学生编号和学生姓名和平均成绩
-- 4、查询平均成绩小于60分的同学的学生编号和学生姓名和平均成绩
-- 5、查询所有同学的学生编号、学生姓名、选课总数、所有课程的总成绩
-- 6、查询"李"姓老师的数量
-- 7、查询学过"张三"老师授课的同学的信息
-- 8、查询没学过"张三"老师授课的同学的信息
-- 9、查询学过编号为"01"并且也学过编号为"02"的课程的同学的信息
-- 10、查询学过编号为"01"但是没有学过编号为"02"的课程的同学的信息
-- 11、查询没有学全所有课程的同学的信息
-- 12、查询至少有一门课与学号为"01"的同学所学相同的同学的信息
-- 13、查询和"01"号的同学学习的课程完全相同的其他同学的信息
-- 14、查询没学过"张三"老师讲授的任一门课程的学生姓名
-- 15、查询两门及其以上不及格课程的同学的学号,姓名及其平均成绩
-- 16、检索"01"课程分数小于60,按分数降序排列的学生信息
-- 17、按平均成绩从高到低显示所有学生的所有课程的成绩以及平均成绩
-- 18、查询各科成绩最高分、最低分和平均分:以如下形式显示:课程ID,课程name,最高分,最低分,平均分,及格率,中等率,优良率,优秀率
-- 19、按各科成绩进行排序,并显示排名(实现不完全)
-- 20、查询学生的总成绩并进行排名
-- 21、查询不同老师所教不同课程平均分从高到低显示
-- 22、查询所有课程的成绩第2名到第3名的学生信息及该课程成绩
-- 23、统计各科成绩各分数段人数:课程编号,课程名称,[100-85],[85-70],[70-60],[0-60]及所占百分比
-- 24、查询学生平均成绩及其名次
-- 25、查询各科成绩前三名的记录
-- 26、查询每门课程被选修的学生数
-- 27、查询出只有两门课程的全部学生的学号和姓名
-- 28、查询男生、女生人数
-- 29、查询名字中含有"风"字的学生信息
-- 30、查询同名同性学生名单,并统计同名人数
-- 31、查询1990年出生的学生名单
-- 32、查询每门课程的平均成绩,结果按平均成绩降序排列,平均成绩相同时,按课程编号升序排列
-- 33、查询平均成绩大于等于85的所有学生的学号、姓名和平均成绩
-- 34、查询课程名称为"数学",且分数低于60的学生姓名和分数
-- 35、查询所有学生的课程及分数情况;
-- 36、查询任何一门课程成绩在70分以上的姓名、课程名称和分数
-- 37、查询不及格的课程
-- 38、查询课程编号为01且课程成绩在80分以上的学生的学号和姓名
-- 39、求每门课程的学生人数
-- 40、查询选修"张三"老师所授课程的学生中,成绩最高的学生信息及其成绩
-- 41、查询不同课程成绩相同的学生的学生编号、课程编号、学生成绩
-- 42、查询每门功成绩最好的前两名
-- 43、统计每门课程的学生选修人数(超过5人的课程才统计);要求输出课程号和选修人数,查询结果按人数降序排列。
-- 44、检索至少选修两门课程的学生学号
-- 45、查询选修了全部课程的学生信息
-- 46、查询各学生的年龄
-- 47、查询本周过生日的学生
-- 48、查询下周过生日的学生
-- 49、查询本月过生日的学生
-- 50、查询下月过生日的学生
执行SQL
-- 1、查询"01"课程比"02"课程成绩高的学生的信息及课程分数
SELECT a.c_id,a.c_score,a.s_id,s1.s_name FROM
student AS s1,
(SELECT s_id,c_id,c_score FROM score WHERE c_id = '01') AS a,
(SELECT s_id,c_id,c_score FROM score WHERE c_id = '02') AS b
WHERE a.s_id = b.s_id
AND a.c_score > b.c_score
AND s1.s_id = a.s_id
-- 2、查询"01"课程比"02"课程成绩低的学生的信息及课程分数
SELECT a.c_id,a.c_score,a.s_id,s1.s_name FROM
student AS s1,
(SELECT s_id,c_id,c_score FROM score WHERE c_id = '01') AS a,
(SELECT s_id,c_id,c_score FROM score WHERE c_id = '02') AS b
WHERE a.s_id = b.s_id
AND a.c_score < b.c_score
AND s1.s_id = a.s_id
-- 3、查询平均成绩大于等于60分的同学的学生编号和学生姓名和平均成绩
SELECT
FORMAT( AVG( a.c_score ), 2 ) AS smu, a.s_id, b.s_name
FROM
score a, student b
WHERE
b.s_id = a.s_id
GROUP BY
a.s_id
HAVING
smu >= 60
-- 4、查询平均成绩小于60分的同学的学生编号和学生姓名和平均成绩
SELECT
FORMAT( AVG( a.c_score ), 2 ) AS smu, a.s_id, b.s_name
FROM
score a, student b
WHERE
b.s_id = a.s_id
GROUP BY
a.s_id
HAVING
smu < 60
-- 5、查询所有同学的学生编号、学生姓名、选课总数、所有课程的总成绩
SELECT
SUM(b.c_score) AS '总成绩',
COUNT(b.c_id) AS '选课数量',
a.s_id,
a.s_name
FROM student a
INNER JOIN score b ON a.s_id = b.s_id
GROUP BY a.s_id
-- 6、查询"李"姓老师的数量
SELECT COUNT(1) FROM teacher WHERE LEFT(t_name,1) = '李'
-- 7、查询学过"张三"老师授课的同学的信息
SELECT
a.c_id,
b.s_name
FROM
score a
INNER JOIN student b ON a.s_id = b.s_id
WHERE
a.c_id = (
SELECT
b.c_id
FROM
teacher a
INNER JOIN course b ON a.t_id = b.t_id
WHERE
t_name = '张三')
-- 8、查询没学过"张三"老师授课的同学的信息
SELECT
*
FROM
student
WHERE
s_id NOT IN (
SELECT b.s_id FROM score a INNER JOIN student b ON a.s_id = b.s_id
WHERE
a.c_id = ( SELECT b.c_id FROM teacher a INNER JOIN course b ON a.t_id = b.t_id WHERE t_name = '张三' )
)
-- 9、查询学过编号为"01"并且也学过编号为"02"的课程的同学的信息
SELECT
b.s_id,
a.s_name,
b.c_id
FROM student a
INNER JOIN score b ON a.s_id = b.s_id
WHERE b.c_id = '02'
AND a.s_id IN
(
SELECT
b.s_id
FROM student a
INNER JOIN score b ON a.s_id = b.s_id
WHERE b.c_id = '01'
)
-- 10、查询学过编号为"01"但是没有学过编号为"02"的课程的同学的信息
SELECT
b.s_id,
a.s_name,
b.c_id
FROM student a
INNER JOIN score b ON a.s_id = b.s_id
WHERE b.c_id = '01'
AND a.s_id NOT IN
(
SELECT
b.s_id
FROM student a
INNER JOIN score b ON a.s_id = b.s_id
WHERE b.c_id = '02'
)
-- 11、查询没有学全所有课程的同学的信息
SELECT
*
FROM
student
WHERE
s_id NOT IN (
SELECT
s1.s_id
FROM
student s1,
score s2,
score s3,
score s4
WHERE
s2.s_id = s3.s_id
AND s2.s_id = s4.s_id
AND s2.c_id = '01'
AND s3.c_id = '02'
AND s4.c_id = '03'
AND s1.s_id = s2.s_id
)
-- 12、查询至少有一门课与学号为"01"的同学所学相同的同学的信息
SELECT
*
FROM
student
WHERE
s_id IN ( SELECT DISTINCT a.s_id FROM score a
WHERE a.c_id IN ( SELECT a.c_id FROM score a WHERE a.s_id = '01' ) );
-- 13、查询和"01"号的同学学习的课程完全相同的其他同学的信息
SELECT
*
FROM student s1
WHERE NOT EXISTS (
SELECT * FROM score s2 WHERE s2.s_id = '01'
AND NOT EXISTS ( SELECT * FROM score s3 WHERE s3.c_id = s2.c_id AND s3.s_id = s1.s_id )
)
AND NOT EXISTS (
SELECT * FROM score s2 WHERE s2.s_id = s1.s_id
AND NOT EXISTS ( SELECT * FROM score s3 WHERE s3.c_id = s2.c_id AND s3.s_id = '01' )
)
AND s1.s_id <> '01'
-- 14、查询没学过"张三"老师讲授的任一门课程的学生姓名
SELECT
*
FROM
student
WHERE
s_id IN (
SELECT DISTINCT s1.s_id FROM score s1
WHERE
s1.s_id NOT IN ( SELECT DISTINCT s_id FROM score
WHERE c_id IN ( SELECT c_id FROM course
WHERE t_id IN ( SELECT t_id FROM teacher WHERE t_name = '张三' ) )))
-- 15、查询两门及其以上不及格课程的同学的学号,姓名及其平均成绩
SELECT
s1.s_id,
FORMAT(AVG(s1.c_score),1) AS '平均成绩',
s2.s_name
FROM score s1,student s2
WHERE s1.c_score < 60
AND s1.s_id = s2.s_id
GROUP BY s1.s_id
HAVING
COUNT(1) >= 2
-- 16、检索"01"课程分数小于60,按分数降序排列的学生信息
SELECT
s1.c_score,
s2.s_name
FROM score s1,student s2
WHERE s1.c_id = '01'
AND s1.c_score < 60
AND s1.s_id = s2.s_id
ORDER BY s1.c_score DESC
-- 17、按平均成绩从高到低显示所有学生的所有课程的成绩以及平均成绩
SELECT
s2.s_name,
(SELECT c_score FROM score WHERE s_id = s1.s_id AND c_id = '01') AS '语文',
(SELECT c_score FROM score WHERE s_id = s1.s_id AND c_id = '02') AS '数学',
(SELECT c_score FROM score WHERE s_id = s1.s_id AND c_id = '03') AS '英语',
AVG(s1.c_score) AS '平均成绩'
FROM score s1,student s2
WHERE s1.s_id = s2.s_id
GROUP BY s1.s_id
ORDER BY AVG(s1.c_score) DESC
-- 18、查询各科成绩最高分、最低分和平均分:以如下形式显示:课程ID,课程name,最高分,最低分,平均分,及格率,中等率,优良率,优秀率
SELECT
s1.c_id,
c1.c_name,
MAX(s1.c_score) AS '最高分',
MIN(s1.c_score) AS '最低分',
FORMAT(AVG(s1.c_score),1) AS '平均分',
COUNT(IF(s1.c_score >= 60,TRUE,NULL)) / COUNT(c1.c_id) AS '及格率',
COUNT(IF(s1.c_score >= 70 AND s1.c_score < 80,TRUE,NULL)) / COUNT(c1.c_id) AS '中等率',
COUNT(IF(s1.c_score >= 80 AND s1.c_score < 90,TRUE,NULL)) / COUNT(c1.c_id) AS '优良率',
COUNT(IF(s1.c_score >= 90 AND s1.c_score <= 100,TRUE,NULL)) / COUNT(c1.c_id) AS '优秀率'
FROM score s1,course c1
WHERE s1.c_id = c1.c_id
GROUP BY s1.c_id
-- 19、按各科成绩进行排序,并显示排名(实现不完全)
SELECT
*,
ROW_NUMBER () OVER (ORDER BY s1.c_score DESC) AS row_num
FROM score s1
ORDER BY row_num ASC
-- 20、查询学生的总成绩并进行排名
SELECT
s1.s_id,
SUM(s1.c_score) AS num,
ROW_NUMBER () OVER (ORDER BY SUM(s1.c_score) DESC) AS row_num
FROM score s1
GROUP BY s1.s_id
ORDER BY row_num ASC
-- 21、查询不同老师所教不同课程平均分从高到低显示
SELECT
t1.t_name,
c1.c_name,
FORMAT(AVG(s1.c_score),1) AS '平均分'
FROM score s1 , course c1,teacher t1
WHERE s1.c_id = c1.c_id
AND c1.t_id = t1.t_id
GROUP BY s1.c_id
ORDER BY AVG(s1.c_score) DESC
-- 22、查询所有课程的成绩第2名到第3名的学生信息及该课程成绩
SELECT
s1.*
FROM
(
SELECT
*,
ROW_NUMBER () OVER (ORDER BY s1.c_score DESC) AS row_num
FROM score s1
) s1
WHERE s1.row_num IN ('2','3')
-- 23、统计各科成绩各分数段人数:课程编号,课程名称,[100-85],[85-70],[70-60],[0-60]及所占百分比
SELECT
s1.c_id,
c1.c_name,
COUNT(IF(s1.c_score < 60,TRUE,NULL)) / COUNT(s1.c_score) AS '0-60',
COUNT(IF(s1.c_score >= 60 AND s1.c_score < 70,TRUE,NULL)) / COUNT(s1.c_score) AS '70-60',
COUNT(IF(s1.c_score >= 70 AND s1.c_score < 85,TRUE,NULL)) / COUNT(s1.c_score) AS '85-70',
COUNT(IF(s1.c_score >= 85 AND s1.c_score <= 100,TRUE,NULL)) / COUNT(s1.c_score) AS '100-85'
FROM score s1,course c1
WHERE s1.c_id = c1.c_id
GROUP BY s1.c_id
-- 24、查询学生平均成绩及其名次
SELECT
FORMAT(AVG(s1.c_score),1) AS '平均成绩',
ROW_NUMBER () OVER (ORDER BY AVG(s1.c_score) DESC) AS row_num
FROM score s1
GROUP BY s1.s_id
-- 25、查询各科成绩前三名的记录
SELECT
*
FROM score s1
WHERE
(
SELECT
COUNT(1)
FROM score s2
WHERE s1.c_id = s2.c_id
AND s1.c_score <= s2.c_score
) <= 3
ORDER BY s1.c_id,s1.c_score DESC
-- 26、查询每门课程被选修的学生数
SELECT
c1.c_name,
COUNT(1) AS '学生数'
FROM score s1 , course c1
WHERE s1.c_id = c1.c_id
GROUP BY s1.c_id
-- 27、查询出只有两门课程的全部学生的学号和姓名
SELECT
s2.s_id,
s2.s_name
FROM score s1 ,student s2
WHERE s1.s_id = s2.s_id
GROUP BY s1.s_id
HAVING COUNT(s1.c_score) = 2
-- 28、查询男生、女生人数
SELECT
COUNT(IF(s1.s_sex = '男',TRUE,NULL)) AS '男生数量',
COUNT(IF(s1.s_sex = '女',TRUE,NULL)) AS '女生数量'
FROM student s1
-- 29、查询名字中含有"风"字的学生信息
SELECT
*
FROM student s1
WHERE s1.s_name LIKE '%风%'
-- 30、查询同名同性学生名单,并统计同名人数
SELECT
s1.*,
s2.`同名人数`
FROM
(
SELECT
COUNT(1) AS '同名同性人数',
s1.s_id,
s1.s_name
FROM student s1
GROUP BY s1.s_name,s1.s_sex
) s1 ,
(
SELECT
COUNT(1) AS '同名人数',
s1.s_id,
s1.s_name
FROM student s1
GROUP BY s1.s_name
) s2
WHERE s1.s_id = s2.s_id
-- 31、查询1990年出生的学生名单
SELECT
*
FROM student s1
WHERE s1.s_birth LIKE '1990%'
-- 32、查询每门课程的平均成绩,结果按平均成绩降序排列,平均成绩相同时,按课程编号升序排列
SELECT
FORMAT(AVG(s1.c_score),1) AS '平均成绩'
FROM score s1
GROUP BY s1.c_id
ORDER BY FORMAT(AVG(s1.c_score),1) DESC ,s1.c_id ASC
-- 33、查询平均成绩大于等于85的所有学生的学号、姓名和平均成绩
SELECT
s2.s_name,
s2.s_id,
FORMAT(AVG(s1.c_score),1) AS '平均成绩'
FROM score s1,student s2
WHERE s1.s_id = s2.s_id
GROUP BY s1.s_id
HAVING FORMAT(AVG(s1.c_score),1) >= 85
-- 34、查询课程名称为"数学",且分数低于60的学生姓名和分数
SELECT
s2.s_name,
s1.c_score,
c1.c_name
FROM course c1
INNER JOIN score s1 ON c1.c_id = s1.c_id
INNER JOIN student s2 ON s1.s_id = s2.s_id
WHERE c1.c_name = '数学'
AND s1.c_score < 60
-- 35、查询所有学生的课程及分数情况
SELECT s1.*,c1.c_name FROM score s1, course c1 WHERE s1.c_id = c1.c_id
-- 36、查询任何一门课程成绩在70分以上的姓名、课程名称和分数
SELECT
s1.c_score,
s2.s_name,
c1.c_name
FROM score s1,student s2, course c1
WHERE s1.c_score > 70
AND s1.s_id = s2.s_id
AND s1.c_id = c1.c_id
-- 37、查询不及格的课程
SELECT
s1.*,
c1.c_name
FROM score s1 ,course c1
WHERE s1.c_score < 60
AND s1.c_id = c1.c_id
-- 38、查询课程编号为01且课程成绩在80分以上的学生的学号和姓名
SELECT
s1.*,
s2.s_name
FROM score s1 , student s2
WHERE s1.c_id = '01'
AND s1.c_score >= 80
AND s1.s_id = s2.s_id
-- 39、求每门课程的学生人数
SELECT
COUNT(s1.s_id) AS '学生人数'
FROM score s1
GROUP BY s1.c_id
-- 40、查询选修"张三"老师所授课程的学生中,成绩最高的学生信息及其成绩
SELECT
MAX(s1.c_score),
c1.c_name,
s1.s_id
FROM teacher t1
INNER JOIN course c1 ON t1.t_id = c1.t_id
INNER JOIN score s1 ON c1.c_id = s1.c_id
WHERE t1.t_name = '张三'
-- 41、查询不同课程成绩相同的学生的学生编号、课程编号、学生成绩
SELECT
s1.c_id,
s1.c_score,
s1.s_id
FROM
(
SELECT
DISTINCT s1.s_id,
s1.c_score,
s1.c_id
FROM score s1 ,score s2
WHERE s1.s_id = s2.s_id
AND s1.c_id <> s2.c_id
AND s1.c_score = s2.c_score
) s1
-- 42、查询每门功成绩最好的前两名
SELECT
*
FROM score s1
WHERE
(
SELECT
COUNT(1)
FROM score s2
WHERE s1.c_id = s2.c_id
AND s1.c_score <= s2.c_score
) <= 2
ORDER BY s1.c_id,s1.c_score DESC
-- 43、统计每门课程的学生选修人数(超过5人的课程才统计);要求输出课程号和选修人数,查询结果按人数降序排列。
SELECT
COUNT(s1.s_id) AS num,
s1.c_id
FROM score s1
GROUP BY s1.c_id
HAVING num > 5
ORDER BY num DESC
-- 44、检索至少选修两门课程的学生学号
SELECT
COUNT(s1.c_id) AS num,
s1.s_id
FROM score s1
GROUP BY s1.s_id
HAVING num >= 2
-- 45、查询选修了全部课程的学生信息
SELECT
*
FROM student s1
WHERE NOT EXISTS
(
SELECT
*
FROM course c1
WHERE NOT EXISTS ( SELECT * FROM score s2 WHERE s1.s_id = s2.s_id AND s2.c_id = c1.c_id )
)
-- 46、查询各学生的年龄
SELECT
s1.s_name,
TIMESTAMPDIFF(YEAR,s1.s_birth,CURDATE()) AS '年龄'
FROM student s1
-- 47、查询本周过生日的学生
select * from student s1
where WEEKOFYEAR(CONCAT( DATE_FORMAT(CURRENT_DATE,'%Y'), '-',DATE_FORMAT(s1.s_birth,'%m-%d') ) ) = WEEKOFYEAR(CURRENT_DATE)
-- 48、查询下周过生日的学生
select * from student s1
where WEEKOFYEAR(CONCAT(DATE_FORMAT(CURRENT_DATE,'%Y'),'-',DATE_FORMAT(s1.s_birth,'%m-%d'))) = WEEKOFYEAR(CURRENT_DATE)+1
-- 49、查询本月过生日的学生
SELECT * FROM student s1 WHERE MONTH(s1.s_birth) = MONTH(CURDATE())
-- 50、查询下月过生日的学生
SELECT * FROM student s1 WHERE MONTH(s1.s_birth) - MONTH(CURDATE()) = 1
ps:
一只小菜鸟 一直在学习 从未敢停止