一
(1)学生“刘家顺”要退学,请删除该学生的所有记录,包括选课记录和学生
记录。
delete
from sc
where sno =
(select sno
from student
where sname='刘家顺');
delete
from student
where sname='刘家顺';
commit;
(2)田小亮同学要转专业,他的学号为103465,将该同学的专业由原来的
“软件工程”改为“计算机科学与技术”,班级由原来的“软工3班”修改为“计算
机1班”。
update student
set smajor='计算机科学与技术',sclass='计算机1班'
where sno='103465';
commit;
(3)删除选修了“嵌入式系统与应用”但没有及格的选课记录。
delete
from sc
where grade<60 and cno in
(select cno
from course
where cname='嵌入式系统与应用');
commit;
(4)将元组(1203076,吕一鸣,男,1985/11/8,讲师,体育部)插入教
师关系。
insert
into teacher(tno,tname,tsex,tbirth,ttitle,tcollege)
values('1203076','吕一鸣','男',to_date('1985/11/8','yyyy/mm/dd'),
'讲师','体育部');
commit;
(5)在course表中插入以下两门课程信息:
课程号:3094217,课程名:图与网络,课程学分:2,课程性质:选修,课
程学时:32,开课学期:6
课程号:3094215,课程名:智能搜索与推荐技术,课程学分:2,课程性
质:选修,课程学时:32,开课学期:7
insert
into course
values('3094217','图与网络',2,'选修',32,'6');
insert
into course
values('3094215','智能搜索与推荐技术',2,'选修',32,'7');
commit;
(6)创建名为xg_view的视图,在视图中显示所有信息工程学院教师的授课
信息,包括教师姓名,职称,所授课程名称,授课班级,授课学期。
create view xg_view(tno,ttitle,cname,tclass,tterm)
as
select teacher.tno,ttitle,cname,sclass,cterm
from teacher,course,tc
where teacher.tno=tc.tno and tc.cno=course.cno;
(7)创建每个学生已修课程总学分的视图,视图名为xf_view,要求在视
图中显示学生学号、姓名和总学分。
create view xf_view(sno,sname,credit)
as
select student.sno,sname,sum(credit)
from sc,student,course
where student.sno=sc.sno and course.cno=sc.cno
group by student.sno,sname;
(8)在创建的视图中查询大数据2班每位学生已修的总学分。
select credit
from xf_view
where sno in
(select sno
from student
where sclass='大数据2班');
(9)在系统表user_updatable_columns中查看视图xf_view是否可以更新
,如果不能请分析原因。
二
(1)现有一供应商,代码为s9、姓名为英特尔、所在城市西安,供应情况
如下:供应零件p5给工程j7数量为600,供应零件p4给工程j4数量为500,
请将此供应商的信息和供应信息插入数据库。
insert
into s(sno,sname,city)
values('s9','英特尔','西安');
commit;
insert
into spj
values('s9','p5','j7',600);
insert
into spj
values('s9','p4','j4',500);
commit;
(2)请将北京供应商的供应数量加150。
update spj
set qty=qty+150
where sno in
(select sno
from s
where city='北京');
commit;
(3)把全部红色零件的颜色改为黑色。
update p
set color='黑色'
where color='红色';
commit;
(4)由s5供给j4的零件p6改为由s1供应。
update spj
set sno='s1'
where sno='s5' and pno='p6' and jno='j4';
commit;
(5)请将(s2,j7,p4,510)插入供应情况关系。
(6)零件p1已经停产,请将p1的相关信息从数据库中删除。
delete
from spj
where pno='p1';
delete
from p
where pno='p1';
commit;
(7)创建零件名为螺丝刀的供应情况的视图sd_view,视图中显示供应商
名(Sname),零件名(Pname),零件重量(Weight),工程项目代码
(Jno),供应数量(QTY)。
create view sd_view(sname,pname,weight,jno,qty)
as
select sname,pname,weight,jno,qty
from s,p,spj
where s.sno=spj.sno and p.pno=spj.pno and pname='螺丝刀';
(8)在视图sd_view中查询供应数量在400到600之间的供应商姓名。
select distinct sname
from sd_view
where qty>=400 and qty<=600;
(9)请为三建工程项目建立一个供应情况的视图SJ_View,包括供应商编
号,零件编号,供应数量。
create view sj_view(sno,pno,qty)
as
select sno,pno,qty
from spj,j
where spj.jno=j.jno and jname='三建';