表结构:
表Student
(S#,Sname,Sage,Ssex) 学生表
S# |
student_no |
Sage |
student_age |
Ssex |
student_sex |
表Course
(C#,Cname,T#) 课程表
C# |
course_no |
Cname |
course_name |
T# |
teacher_no |
表SC(学生与课程的分数mapping 表)
(S#,C#,score) 成绩表
S# |
student_no |
C# |
course_no |
score |
分数啦 |
表Teacher
(T#,Tname) 教师表
T# |
teacher_no |
Tname |
teacher_name |
-------开发库-------
--学生表
select * from Student;
--成绩表
select * from sc;
--教师表
select * from teacher;
--课程表
select * from course;
1、查询“001”课程比“002”课程成绩高的所有学生的学号;
select a.S#
from (select s#,score from SC where C#='001') a,(select s#,score
from SC where C#='002')
where a.score>b.score and a.s#=b.s#;
select S#,avg(score)
from sc
group by S# having avg(score) >60;
select Student.S#,Student.Sname,count(SC.C#),sum(score)
from Student left Outer join SC on Student.S#=SC.S#
group by Student.S#,Sname
select count(distinct(Tname))
from Teacher
where Tname like '李%';
select Student.S#,Student.Sname
from Student
where S# not in (select distinct( SC.S#) fromSC,Course,Teacher where SC.C#=Course.C#and Teacher.T#=Course.T# andTeacher.Tname='叶平');
6、查询学过“001”并且也学过编号“002”课程的同学的学号、姓名;
select Student.S#,Student.Sname
fromStudent,SC
where Student.S#=SC.S# andSC.C#='001
'and exists( Select * from SC as SC_2 whereSC_2.S#=SC.S# and SC_2.C#='002');
select S#,Sname
from Student
where S# in (select S# from SC,Course ,Teacher where SC.C#=Course.C# andTeacher.T#=Course.T# and Teacher.Tname='叶平'group by S# havingcount(SC.C#)=(select count(C#) fromCourse,Teacher whereTeacher.T#=Course.T# and Tname='叶平'));
8、查询课程编号“002”的成绩比课程编号“001”课程低的所有同学的学号、姓名;
Select S#,Sname from (select Student.S#,Student.Sname,score ,(select score from SCSC_2 where SC_2.S#=Student.S#and SC_2.C#='002') score2
from Student,SC where Student.S#=SC.S# andC#='001') S_2 where score2 <score;
select S#,Sname
from Student
where S# not in (select Student.S# fromStudent,SC where S.S#=SC.S# andscore>60);
select Student.S#,Student.Sname
from Student,SC
whereStudent.S#=SC.S# group by Student.S#,Student.Sname having count(C#) <(select count(C#) from Course);
11、查询至少有一门课与学号为“1001”的同学所学相同的同学的学号和姓名;
select S#,Sname from Student,SC whereStudent.S#=SC.S# and C# in select C# from SC where S#='1001';