sql查询语句练习(解析版)
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
sql查询语句练习(解析版)BY DD
表情况
Student(S#,Sname,Sage,Ssex) 学生表
Course(C#,Cname,T#) 课程表
SC(S#,C#,score) 成绩表
Teacher(T#,Tname) 教师表
create table Student(S# varchar2(20),Sname varchar2(10),Sage int,Ssex varchar2(2)) ;
create table Course(C# varchar2(20),Cname varchar2(10),score varchar2(4)) ;
create table SC(S# varchar2(20),C# varchar2(20),score varchar2(4)) ;
create table Teacher(T# varchar2(20),Tname varchar2(10)) ;
insert into Student(S#,Sname,Sage,Ssex) values('1001','李五','15','男');
insert into Student(S#,Sname,Sage,Ssex) values('1002','张三','16','女');
insert into Student(S#,Sname,Sage,Ssex) values('1003','李四','15','女');
insert into Student(S#,Sname,Sage,Ssex) values('1004','陈二','14','男');
insert into Student(S#,Sname,Sage,Ssex) values('1005','小四','15','男');
问题:
1、查询“001”课程比“002”课程成绩高的所有学生的学号;
select a.S# from (select s#,score from SC where C#='001') a,(select s#,score
from SC where C#='002') b
where a.score>b.score and a.s#=b.s#;
解析:(select s#,score from SC where C#='001') a//从SC中查询C#=001的学生学号和分数,并定义为a表。
(select s#,score from SC where C#='002') b //从SC中查询C#=002的学生学号和分数,并定义为b表。
where a.score>b.score and a.s#=b.s# 条件,a表与b表中学号相同且分数比b中的高。
2、查询平均成绩大于60分的同学的学号和平均成绩;
select S#,avg(score) rom sc
group by S# having avg(score) >60;
解析: group by S# having avg(score) >60 这里是指平均分数大于60分的
学号。使用HAVING 子句原因是,WHERE 关键字无法与合计函数一起使用。
合计函数 (比如 SUM) 常常需要添加 GROUP BY 语句,根据一个或多个列对结果集进行分组。
3、查询所有同学的学号、姓名、选课数、总成绩;
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
解析: Student left Outer join SC on Student.S#=SC.S# 左外连接,从student表返回所有的行放于左表中,从SC中返回的与左表匹配的行放于右表。Student表中有但SC表中没有的在右表中对应行留空。
group by Student.S#,Sname 以 Student.S#,Sname分组。
4、查询姓“李”的老师的个数;
select count(distinct(Tname))
from Teacher
where Tname like'李%';
解析:distinct(Tname) 在表中,可能会包含重复值。DISTINCT 用于返回唯一不同的值,这里的作用就是防止返回的Tname出现重复值。
where Tname like '李%' 模糊查询,"%"代表一或多个字符。
5、查询没学过“叶平”老师课的同学的学号、姓名;
Select Student.S#,Student.Sname
from Student
where S# not in(select distinct(SC.S#) from SC,Course,Teacher where SC.C#=Course.C# and Teacher.T#=Course.T# and Teacher.Tname='叶平');
解析:not in 题目是查询没学过“叶平”老师课的同学的学号、姓名,这里使用not in 就表示所要查询的S#不在后面的结果中。
(select distinct(SC.S#) from SC,Course,Teacher where SC.C#=Course.C# and Teacher.T#=Course.T# and Teacher.Tname='叶平');
这段语句是查询学过“叶平”老师课的同学的学号,这里其实查询的SC表,但可看到查的表是SC,Course,Teacher表,根据后面的条件语句,用来关联查询的。三个条件要同时满足,从而查询出“叶平”老师课的同学的学号
SC.C#=Course.C#,Teacher.T#=Course.T# 由于SC与Teacher并无直接联系,