mysql练习题(1~10)

编程入门 行业动态 更新时间:2024-10-04 03:24:33

mysql<a href=https://www.elefans.com/category/jswz/34/1766964.html style=练习题(1~10)"/>

mysql练习题(1~10)

文章目录

    • 材料
    • 1.查询“001”课程比“002”课程成绩高的所有学生的学号;
    • 2、查询平均成绩大于60分的同学的学号和平均成绩;
    • 3、查询所有同学的学号、姓名、选课数、总成绩;
    • 4、查询姓“李”的老师的个数;
    • 5、查询没学过“叶平”老师课的同学的学号、姓名;
    • 6、查询学过“001”并且也学过编号“002”课程的同学的学号、姓名;
    • 7、查询学过“叶平”老师所教的所有课的同学的学号、姓名;
    • 8、查询课程编号“002”的成绩比课程编号“001”课程低的所有同学的学号、姓名;
    • 9、查询所有课程成绩小于60分的同学的学号、姓名;
    • 10、查询没有学全所有课的同学的学号、姓名;

材料

ORACLE(表+数据)
CREATE TABLE student (
sid varchar2(10) NOT NULL,
sName varchar2(20) DEFAULT NULL,
sAge date ,
sSex varchar2(10) DEFAULT NULL,
PRIMARY KEY (sid)
)

CREATE TABLE course (
cid varchar2(10) NOT NULL,
cName varchar2(10) DEFAULT NULL,
tid number(20) DEFAULT NULL,
PRIMARY KEY (cid)
)

CREATE TABLE sc (
sid varchar2(10) DEFAULT NULL,
cid varchar2(10) DEFAULT NULL,
score number(10) DEFAULT NULL
)

CREATE TABLE teacher (
tid number(10) DEFAULT NULL,
tName varchar2(10) DEFAULT NULL
)

insert into course(cid,cName,tid) values (‘001’,‘企业管理’,3);
insert into course(cid,cName,tid) values (‘002’,‘马克思’,3);
insert into course(cid,cName,tid) values (‘004’,‘数据库’,1);
insert into course(cid,cName,tid) values (‘005’,‘英语’,1);

insert into sc(sid,cid,score) values (‘1001’,‘001’,80);
insert into sc(sid,cid,score) values (‘1001’,‘002’,60);
insert into sc(sid,cid,score) values (‘1001’,‘003’,70);
insert into sc(sid,cid,score) values (‘1002’,‘001’,85);
insert into sc(sid,cid,score) values (‘1002’,‘002’,70);
insert into sc(sid,cid,score) values (‘1003’,‘004’,90);
insert into sc(sid,cid,score) values (‘1003’,‘001’,90);
insert into sc(sid,cid,score) values (‘1003’,‘002’,99);
insert into sc(sid,cid,score) values (‘1004’,‘002’,65);
insert into sc(sid,cid,score) values (‘1004’,‘003’,50);
insert into sc(sid,cid,score) values (‘1005’,‘005’,80);
insert into sc(sid,cid,score) values (‘1005’,‘004’,70);
insert into sc(sid,cid,score) values (‘1003’,‘003’,10);
insert into sc(sid,cid,score) values (‘1003’,‘005’,10);

insert into student(sid,sName,sAge,sSex) values (‘1001’,‘张三丰’,to_date(‘1980-10-12 23:12:36’,‘YYYY-MM-DD HH24:MI:SS’),‘男’);
insert into student(sid,sName,sAge,sSex) values (‘1002’,‘张无极’,to_date(‘1995-10-12 23:12:36’,‘YYYY-MM-DD HH24:MI:SS’),‘男’);
insert into student(sid,sName,sAge,sSex) values (‘1003’,‘李奎’,to_date(‘1992-10-12 23:12:36’,‘YYYY-MM-DD HH24:MI:SS’),‘女’);
insert into student(sid,sName,sAge,sSex) values (‘1004’,‘李元宝’,to_date(‘1980-10-12 23:12:36’,‘YYYY-MM-DD HH24:MI:SS’),‘女’);
insert into student(sid,sName,sAge,sSex) values (‘1005’,‘李世明’,to_date(‘1981-10-12 23:12:36’,‘YYYY-MM-DD HH24:MI:SS’),‘男’);
insert into student(sid,sName,sAge,sSex) values (‘1006’,‘赵六’,to_date(‘1986-10-12 23:12:36’,‘YYYY-MM-DD HH24:MI:SS’),‘男’);
insert into student(sid,sName,sAge,sSex) values (‘1007’,‘田七’,to_date(‘1981-10-12 23:12:36’,‘YYYY-MM-DD HH24:MI:SS’),‘女’);

insert into teacher(tid,tName) values (1,‘李老师’);
insert into teacher(tid,tName) values (2,‘何以琛’);
insert into teacher(tid,tName) values (3,‘叶平’);

teacher: tname, tid
course:tid , cname , cid
sc : cid , score , sid
student: sid , sname ,ssex

问题:

1.查询“001”课程比“002”课程成绩高的所有学生的学号;

SELECT a.sid  FROM (SELECT sid ,score FROM sc where cid = 001) AS a ,
(SELECT sid ,score FROM sc where cid = 002) AS b 
where a.sid = b.sid  and a.score > b.score ;

2、查询平均成绩大于60分的同学的学号和平均成绩;

SELECT sid ,avg(score) FROM sc GROUP BY sid HAVING avg(score) >60;

3、查询所有同学的学号、姓名、选课数、总成绩;

SELECT st.sid ,st.sname ,COUNT(sc.cid),SUM(sc.score) FROM student AS stLEFT JOIN sc on st.sid= sc.sid 
GROUP BY sid;

4、查询姓“李”的老师的个数;

SELECT count(*) FROM teacher WHERE tname LIKE "李%"; 

5、查询没学过“叶平”老师课的同学的学号、姓名;

select Student.sid,Student.Sname 
from Student 
where sid not in (select distinct( SC.sid) from SC INNER JOIN course on SC.cid = course.cid 
INNER JOIN teacher on course.tid = teacher.tid where Teacher.Tname='叶平');

6、查询学过“001”并且也学过编号“002”课程的同学的学号、姓名;

select Student.sid,Student.Sname from Student,SC where Student.sid=SC.sid 
and SC.cid='001'and exists( Select * from SC where sc.cid='002');

7、查询学过“叶平”老师所教的所有课的同学的学号、姓名;

SELECT distinct st.sName , st.sid from student as st inner join sc on sc.sid = st.sid 
inner join course on sc.cid = course.cid inner join teacher on course.tid = teacher.tid 
where teacher.tname = '叶平';

8、查询课程编号“002”的成绩比课程编号“001”课程低的所有同学的学号、姓名;

select st.sid ,st.sname from student as st inner join  (select sid ,score from sc where sc.cid = 001) as a on st.sid = a.sid inner join (select sid ,score from sc where sc.cid = 002) as b on st.sid = b.sid 
where a.score > b.score ;

9、查询所有课程成绩小于60分的同学的学号、姓名;

SELECT distinct st.sid ,st.sname from student as st inner join sc on st.sid = sc.sid 
where sc.score <60;

10、查询没有学全所有课的同学的学号、姓名;

SELECT st.sname ,st.sid from student as st inner join sc on st.sid = sc.sid 
group by st.sid 
having (count(sc.cid)<5);

更多推荐

mysql练习题(1~10)

本文发布于:2024-02-28 06:57:44,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1768594.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:练习题   mysql

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!