SQL练习题

一、创建测试数据

(1)、创建数据库
mysql>create database school;
mysql>use school;
(2)、创建表(可以尝试用powerdesigner工具设计数据库,导出SQL)

/*==============================================================*/
/* DBMS name:      MySQL 5.0                                    */
/* Created on:     2019/4/19 10:34:32                           */
/*==============================================================*/


drop table if exists class;

drop table if exists course;

drop table if exists score;

drop table if exists student;

drop table if exists teacher;

/*==============================================================*/
/* Table: class                                                 */
/*==============================================================*/
create table class
(
   cid                  varchar(10) not null,
   caption              varchar(20) not null,
   primary key (cid)
);

/*==============================================================*/
/* Table: course                                                */
/*==============================================================*/
create table course
(
   cid                  varchar(10) not null,
   cname                varchar(20) not null,
   tid                  varchar(10) not null,
   primary key (cid)
);

/*==============================================================*/
/* Table: score                                                 */
/*==============================================================*/
create table score
(
   sid                  varchar(10) not null,
   cid                  varchar(10) not null,
   score                decimal not null,
   编号                   varchar(10) not null,
   primary key (编号)
);

/*==============================================================*/
/* Table: student                                               */
/*==============================================================*/
create table student
(
   sid                  varchar(10) not null,
   sname                varchar(20) not null,
   gender               varchar(2) not null,
   cid                  varchar(10),
   birth                datetime,
   primary key (sid)
);

/*==============================================================*/
/* Table: teacher                                               */
/*==============================================================*/
create table teacher
(
   tid                  varchar(10) not null,
   tname                varchar(20) not null,
   primary key (tid)
);
Create table

(2)、插入数据

insert into class values('101','一年级一班');
insert into class values('102','一年级二班');
insert into class values('103','一年级三班');
insert into class values('104','一年级四班');
insert into class values('201','二年级一班');
insert into class values('202','二年级二班');
insert into class values('203','二年级三班');

insert into Student values('01' , '赵雷' ,'','101', '1990-01-01');
insert into Student values('02' , '彭万里' ,'','101', '1990-12-21');
insert into Student values('03' , '高大山' ,'','102', '1990-12-20');
insert into Student values('04' , '谢大海' ,'','104', '1990-12-06');
insert into Student values('05' , '林莽' ,'','104', '1991-12-01');
insert into Student values('06' , '章汉夫' ,'','203', '1992-01-01');
insert into Student values('07' , '范长江' ,'','203', '1989-01-01');
insert into Student values('09' , '林君雄' ,'','102', '2017-12-20');
insert into Student values('10' , '谭平山' ,'','201', '2017-12-25');
insert into Student values('11' , '李四光' ,'','203', '2012-06-06');
insert into Student values('12' , '甘铁生' ,'','104', '2013-06-13');
insert into Student values('13' , '程孝先' ,'','102', '2014-06-01');

insert into teacher values('01' , '朱希亮');
insert into teacher values('02' , '黄强辉');
insert into teacher values('03' , '马宏宇');
insert into teacher values('04' , '马继祖');

insert into course values('01' , '语文','01');
insert into course values('02' , '数学','02');
insert into course values('03' , '英语','03');
insert into course values('04' , '历史','04');
insert into course values('05' , '物理','01');

insert into score values('01' , '01', '01',78);
insert into score values('02' , '01', '02',72);
insert into score values('03' , '02', '01',87);
insert into score values('04' , '02', '03',90);
insert into score values('05' , '03', '04',100);
insert into score values('06' , '05', '04',97);
insert into score values('07' , '07', '03',89);
insert into score values('08' , '07', '02',72);
insert into score values('09' , '08', '04',79);
insert into score values('10' , '08', '01',57);
insert into score values('11' , '09', '02',52);
insert into score values('12' , '09', '01',69);
insert into score values('13' , '11', '04',87);
insert into score values('14' , '12', '01',60);
insert into score values('15' , '13', '01',79);
Insert values

 二、练习题

1、查询“语文”课程比“物理”课程成绩高的所有学生的学号;
select A.sid,yw,wl from
(select sid,score as yw from score left join course on score.cid=course.cid where cname='语文') as A
left join (select sid,score as wl from score left join course on score.cid=course.cid where cname='物理') as B
on A.sid=B.sid
where yw>if(isnull(wl),0,wl);
2、查询平均成绩大于60分的同学的学号和平均成绩;
select sid,avg(score) as mean from score group by sid
having mean>60;
3、查询所有同学的学号、姓名、选课数、总成绩;
select score.sid,student.sname,count(score.cid) as 选课数,sum(score.score) as total from score
left join student on score.sid=student.sid
group by sid
4、查询姓“马”的老师的个数;
select count(tname) from teacher where tname like '马%';
5、查询没学过“马宏宇”老师课的同学的学号、姓名;
(1)查询马宏宇老师教的课
select cid from course left join teacher on course.tid=teacher.tid where tname='马宏宇';
(2)查询学过马宏宇老师课程的学生
select score.sid from score
where cid in (select cid from course left join teacher on course.tid=teacher.tid where tname='马宏宇');
(3)查询没有学过马宏宇老师课程的学生
select * from student
where sid not in
(select score.sid from score where cid in (select cid from course left join teacher on course.tid=teacher.tid where tname='马宏宇'));
6、查询学过“01”并且也学过编号“02”课程的同学的学号、姓名;
(1)选出既选01又选02课程的学生学号
select A.sid from (select sid from score where cid='01') as A inner join (select sid from score where cid='02') as B on A.sid=B.sid
(2)查询学生的姓名
select sid ,sname from student where sid in
(select A.sid from (select sid from score where cid='01') as A inner join (select sid from score where cid='02') as B on A.sid=B.sid);

7、查询学过“马宏宇”老师所教的所有课的同学的学号、姓名;
(1)查询马宏宇老师教的课程
select cid from course left join teacher on course.tid=teacher.tid where tname='马宏宇';
(2)查询学过马宏宇老师课程的学生
select student.sid ,sname from student
left join score on student.sid=score.sid
where score.cid in (select cid from course left join teacher on course.tid=teacher.tid where tname='马宏宇');

8、查询课程编号“02”的成绩比课程编号“01”课程低的所有同学的学号、姓名;
(1)查询02比01低的同学的学号
select A.sid,two,one from
(select sid,score as two from score where cid='02') as A
left join
(select sid,score as one from score where cid='01') as B
on A.sid=B.sid
where two<if(isnull(one),0,one)
(2)连表查询学号和姓名
select student.sid ,student.sname,one,two from student right join
(select A.sid,two,one from
(select sid,score as two from score where cid='02') as A
left join
(select sid,score as one from score where cid='01') as B
on A.sid=B.sid
where two<if(isnull(one),0,one)) as C
on student.sid=C.sid;
9、查询有课程成绩小于60分的同学的学号、姓名;
select distinct student.sid,sname from student
right join (select sid ,score from score where score < 60) as A
on student.sid=A.sid;
10、查询没有学全所有课的同学的学号、姓名;
(1)学全五门课程的学生学号
select sid,count(cid) as num from score group by sid having num=5;
(2)查询没有学全五门课程的学生名单
select sid,sname from student
where sid not in
(select sid from score group by sid having count(cid)=5);
11、查询至少有一门课与学号为“01”的同学所学相同的同学的学号和姓名;
select distinct score.sid,sname from score left join student on score.sid=student.sid
where score.cid in (select cid from score where sid = '01')
12、查询至少学过学号为“01”同学所选课程中任意一门课的其他同学学号和姓名;
select distinct score.sid,sname from score left join student on score.sid=student.sid
where score.cid in (select cid from score where sid = '01') and score.sid !='01';
13、查询和“02”号的同学学习的课程完全相同的其他同学学号和姓名;(暂时没有实现,待续……)
select score.sid,sname from score left join student on score.sid=student.sid
where score.cid in (select cid from score where sid='02') and score.sid !='02';

14、删除学习“马继祖”老师课的score表记录;
delete from score where cid in (select cid from teacher left join course on teacher.tid=course.tid where tname='马继祖');
15、向SC表中插入一些记录,这些记录要求符合以下条件:①没有上过编号“02”课程的同学学号;②插入“02”号课程的平均成绩;

(由于涉及到主键,暂时没有实现,待续……)
16、按平均成绩从低到高显示所有学生的“语文”、“数学”、“英语”三门的课程成绩,按如下形式显示: 学生ID,语文,数学,英语,有效课程数,有效平均分; 方法一:
select sid,(select score from score where A.sid=score.sid and cid='01')as yw,
(select score from score where A.sid=score.sid and cid='02')as sx,
(select score from score where A.sid=score.sid and cid='03')as yy, count(A.cid) as num,avg(A.score) as mean
from score as A group by sid
order by mean;
方法二:
select sid,(select score from score left join course on score.cid=course.cid where A.sid=score.sid and cname='语文')as yw,
(select score from score left join course on score.cid=course.cid where A.sid=score.sid and cname='数学')as sx,
(select score from score left join course on score.cid=course.cid where A.sid=score.sid and cname='英语')as yy,
count(A.cid) as num,avg(A.score) as mean
from score as A group by sid
order by mean;

17、查询各科成绩最高和最低的分:以如下形式显示:课程ID,最高分,最低分;
select cid,(select max(score) from score)as max,
(select min(score) from score)as min
from score as A group by cid;
18、按各科平均成绩从低到高和及格率的百分数从高到低顺序;
方法一:
select cid,(select avg(score) from score where A.cid=score.cid)as mean,
((select count(1) from score where score>60)/(count(1))*100) as jgl
from score as A group by cid
order by mean,jgl desc;
方法二:
select cid,(select avg(score) from score where A.cid=score.cid)as mean,
(sum(case when A.score>60 then 1 else 0 end)/(count(1))*100) as jgl
from score as A group by cid
order by mean,jgl desc;
19、课程平均分从高到低显示(显示任课老师);
select cid,cname,tname,mean from teacher right join
(select score.cid,cname,tid,avg(score) as mean from score left join course on score.cid=course.cid group by cid)as A
on teacher.tid=A.tid order by mean desc;
20、查询各科成绩前三名的记录:(不考虑成绩并列情况)? (select sid ,cid ,score from score where cid='01' order by score limit 3)
union
(select sid ,cid ,score from score where cid='02' order by score limit 3)
union
(select sid ,cid ,score from score where cid='03' order by score limit 3)
union
(select sid ,cid ,score from score where cid='04' order by score limit 3)
union
(select sid ,cid ,score from score where cid='05' order by score limit 3);
21、查询每门课程被选修的学生数;
select cid,count(sid) from score group by cid;
22、查询出只选修了一门课程的全部学生的学号和姓名;
select student.sid,sname from student right join
(select sid,count(cid) as num from score group by sid having num=1) as A
on student.sid=A.sid;
23、查询男生、女生的人数;
select gender,count(1) from student group by gender;
24、查询姓“赵”的学生名单;
select * from student where sname like '赵%';
25、查询同名同姓学生名单,并统计同名人数;
select sname,count(1) as num from student group by sname
having num>1;
26、查询每门课程的平均成绩,结果按平均成绩升序排列,平均成绩相同时,按课程号降序排列;
select cid,avg(score) as mean from score group by cid
order by mean,cid desc;
27、查询平均成绩大于60的所有学生的学号、姓名和平均成绩;
select score.sid,sname,avg(score) as mean from score left join student on score.sid=student.sid
having mean>60;
28、查询课程名称为“数学”,且分数低于60的学生姓名和分数;
select sid,cname,score from score left join course on score.cid=course.cid
where score<60 and cname='数学';
29、查询课程编号为03且课程成绩在80分以上的学生的学号和姓名;
select score.sid,sname,score from score left join student on score.sid=student.sid
where score>80 and score.cid='03'
30、求选了课程的学生人数
select count(sid) as num from (select distinct sid from score) as A;
31、查询选修“马宏宇”老师所授课程的学生中,成绩最高的学生姓名及其成绩;
select score.sid,sname,score from score left join student on score.sid=student.sid
where score.cid in (select cid from course left join teacher on course.tid=teacher.tid where tname='马宏宇') order by score desc
limit 1;
32、查询各个课程及相应的选修人数;
select cid ,count(1) from score group by cid;
33、查询不同课程但成绩相同的学生的学号、课程号、学生成绩;
select s1.sid,s1.cid,s1.score from score as s1,score as s2 where s1.score=s2.score and s1.cid!=s2.cid;
34、查询每门课程成绩最好的前两名;
(select cid,sid,score from score where cid='01' order by score desc limit 2)
union
(select cid,sid,score from score where cid='02' order by score desc limit 2)
union
(select cid,sid,score from score where cid='03' order by score desc limit 2)
union
(select cid,sid,score from score where cid='04' order by score desc limit 2)
union
(select cid,sid,score from score where cid='05' order by score desc limit 2);

35、检索至少选修两门课程的学生学号;
select sid ,count(cid) as num from score group by sid having num>1;
36、查询全部学生都选修的课程的课程号和课程名;
select score.cid,cname,count(sid) as num from score left join course on score.cid=course.cid
group by cid having num=(select count(1) from student);

37、查询没学过“马宏宇”老师讲授的任一门课程的学生姓名;
select score.sid,sname from score left join student on score.sid=student.sid
where score.sid not in
(select cid from course left join teacher on course.tid=teacher.tid where tname='马宏宇');

38、查询两门以上不及格课程的同学的学号及其平均成绩;
select score.sid,sname,avg(score) as mean from score left join student on score.sid=student.sid
group by score.sid
having sid in
(select sid from (select sid from score where score<60) as A group by sid having count(1) >2);

39、检索“04”课程分数小于60,按分数降序排列的同学学号;
select sid,score from score where cid='01' and score <60 order by score desc;
40、删除“02”同学的“01”课程的成绩; delete from score where sid='02' and cid='01';

posted @ 2019-04-23 16:36  雪舞飞扬2019  阅读(1023)  评论(0编辑  收藏  举报