数据库系统与应用教程(刘金岭)实验五参考答案

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验四简单查询和连接查询

2. 简单查询实验

用Transact-SQL语句表示下列操作,在“学生选课“数据库中实现其数据查询操作:

(1) 查询数学系学生的学号和姓名。

select sno,sname

from S

where Sdept='MA'

(2) 查询选修了课程的学生学号。

select distinct(sno)

from sc;

(3) 查询选修课程号为‘C2’的学生学号和成绩,并要求对查询结果按成绩降序排列,如果成绩相同则按学号升序排列。

select distinct(sno),grade

from sc

where cno='C2'

order by grade desc,sno asc;

(4) 查询选修课程号为‘C2’的成绩在80-90 分之间的学生学号和成绩,并将成绩乘以系数0.8 输出。

select distinct(sno),grade*0.8 as'sore'

from sc

where cno='C2'and grade between 80 and 90;

(5) 查询数学系(MA)或计算机科学系(CS)姓张的学生的信息。

select*

from S

where dept in('MA','CS')and sname like'张%';

(6) 查询缺少了成绩的学生的学号和课程号。

select sno,cno

from sc

where grade is null;

3. 连接查询实验

用Transact-SQL语句表示,并在“学生选课”数据库中实现下列数据连接查询操作:

(1) 查询每个学生的情况以及他(她)所选修的课程。

select S.*,ame

from S JION sc ON s.sno=sc.sno JION c ON o=o

(2) 查询学生的学号、姓名、选修的课程名及成绩。

select s.sno,sname,cname,grade

from S JION sc ON s.sno=sc.sno JION c ON o=o

(3) 查询选修‘离散数学’课程且成绩为90 分以上的学生学号、姓名及成绩。

select s.sno,sname,grade

from S JION sc ON s.sno=sc.sno and grade>=90 JION c ON

o=o and cname='离散数学'

(4) 查询每一门课的间接先行课(即先行课的先行课)。

select o,second.pcno

from c as first JOIN c as second ON first.pcno=o

4. 嵌套查询

用TransacTransact-SQL语句表示,在学生选课库中实现其数据嵌套查询操作:

(l) 查询选修了“离散数学”的学生学号和姓名。

select sno,sname

from student

where sno in

(select sno

from sc

where cno=

(select cno

from course

where cname='离散数学'));

(2) 查询“C2”课程的成绩高于张林的学生学号和成绩。

select sno,grade

from sc

where cno='C2'and grade>

(select grade

from sc

where cno='C2'and sno=(select sno

From s

Where sname='张林'));

(3) 查询其他系中年龄小于计算机科学系(CS)年龄最大者的学生。

select*

from s

where Sdept<>'CS'and age<(select max(age)

from s

where Sdept='CS');

(4) 查询其他系中比计算机系学生年龄都小的学生。

(3)中的max换成min即可。

(5) 查询同“王洪敏”的“数据库原理及应用”课程分数相同的学生的学号。

select sno

from sc

where grade=(select grade

from S JION sc ON s.sno=sc.sno JION c ON o=o and ame='数据库原理及应用'and sname='王洪敏');

(6) 查询选修了‘C2’课程的学生姓名。

select sname

from s

where sno in(select sno

from sc

where cno='0206');

(7) 查询没有选修‘C2’课程的学生姓名。

在(5)的in前加not即可。

5. 组合查询和统计查询

在学生选课数据库中实现其查询操作:

(1) 查找选修“计算机基础”课程的学生成绩比此课程的平均成绩大的学生学号和成绩。

select x.sno,x.grade

From sc as x

Where x.grade>(

select avg(y.grade)

From sc as y,course as c

Where ame='计算机基础')and o=

(select cno

From course

Where cname='计算机基础');

(2) 查询选修计算机基础课程的学生的平均成绩。

select avg(grade)

From sc

Where sno in

(select sno

From sc

Where cno=

(select cno

From course

Where cname='计算机基础'));

(3) 查询年龄大于女同学平均年龄的男同学姓名和年龄。

select sname,age

From student

Where sex='男'and age>

(select avg(age)

From student

Where sex='女');

(4) 列出各系学生的总人数,并按人数进行降序排列。

select dept ,count(*)as total

From student

Group by dept

order by total desc;

(5) 统计各系各门课程的平均成绩。

select dept ,cno,avg(grade)

From student,sc

Group by dept,cno

(6) 查询选修计算机基础和离散数学的学生学号和平均成绩。

相关文档
最新文档