5. 检索没有选修课程“数据库”的学生的姓名和年龄。 ①SQL命令:
select sname ,year(getdate())-year(birthday) from s
where sno in ( select sno from sc where cno<>'数据库') ②结果:
6. 列出选修课程超过3门的学生姓名和选修门数。 ①SQL命令:
select sname,count(s.sno) as 课程门数 from s,sc where s.sno=sc.sno group by sname
having count(s.sno)>3 ②结果:
7. 求选修了各课程的学生人数。 ①SQL命令:
select cno ,count(sno) as 学生人数 from sc group by cno ②结果:
15
8. 在表SC中求选修课程C01的学生的学号和得分,并将结果按分数降序排序。 ①SQL命令:
select sno,grade from sc order by grade desc ②结果:
9. 查找每个学生的学号及选修课程的平均成绩情况。 ①SQL命令:
select sno ,avg(grade) as 平均分 from sc group by sno ②结果:
10. 创建视图pride7,按照学号升序,将前30%的同学的学号、平均成绩显示出来。 ①SQL命令: create view pride7 as
select top 30 percent sno,avg(grade) as 平均成绩 from sc
group by sno order by sno asc ②结果:
16
11. 创建加密视图pride4,将课程名及课程平均成绩显示出来。 ①SQL命令: create view pride4 with encryption as
select cname,avg(grade) as 平均成绩 from c,sc where c.cno=sc.cno group by cname ②结果:
12. 创建视图pride5,将课程成绩大于80分的学生姓名、课程名及课程成绩显示出来。要求当修改视图pride5时,必须满足限制条件:成绩大于80分。 ①SQL命令: create view pride5 as
select s.sname,cname,grade from s ,c,sc
where s.sno=sc.sno and c.cno=sc.cno and grade >80 with check option ②结果:
13. 从视图pride4中查询课程平均成绩在70到80分之间的课程名。 ①SQL命令:
select cname from pride4
where 平均成绩 between 70 and 80 ②结果:
14. 向视图pride6中,插入一条记录:(j0408,乔海石,1997-07-07,计算机系,女) ①SQL命令:
insert into pride6 values('J0408','乔海石',1997-07-07,'计算机系',null,'女') 15. 删除视图pride6中在1997年出生的所有记录。 ①SQL命令:
delete from pride6 where year(birthday)=1997
17