数据库第五六七章作业答案.ppt
第五章作业1、查询学生选课表中的全部数据、查询学生选课表中的全部数据select*fromsc2、查询计算机系学生的姓名、年龄、查询计算机系学生的姓名、年龄selectsname,sagefromstudentwheresdept=计算机系计算机系3、查询成绩在、查询成绩在70-80的学生的学号、课程号和成绩的学生的学号、课程号和成绩select*fromscwheregradebetween70to804、查询计算机系年龄在、查询计算机系年龄在18-20的男生的姓名、年龄的男生的姓名、年龄selectsname,sagefromstudentWheresdept=计算机系计算机系andsagebetween18to20andssex=男男5、查询、查询“C01”课程的最高成绩课程的最高成绩Selectmax(grade)fromscwherecno=c016、查询计算机系学生的最大年龄和最小年龄、查询计算机系学生的最大年龄和最小年龄selectmax(sage),min(sage)fromstudentwheresdept=计算机系计算机系7、统计每个系的学生人数、统计每个系的学生人数selectsdept,count(*)fromstudentgroupbysdept8、统计每门课程的选课人数和考试最高分、统计每门课程的选课人数和考试最高分selectcno,count(*),max(grade)fromscgroupbycno9、统计每个学生的选课门数和考试总成绩,并按选课门数、统计每个学生的选课门数和考试总成绩,并按选课门数升序显示结果升序显示结果selectsno,count(*),sum(grade)fromscgroupbysnoorderbycount(*)asc10、查询总成绩超过、查询总成绩超过200分的学生,要求列出学号、总成绩分的学生,要求列出学号、总成绩selectsno,sum(grade)fromscgroupbysnohavingsum(grade)20011、查询选修了、查询选修了”C02“课程的学生的姓名和所在系课程的学生的姓名和所在系selectsname,sdeptfromstudentsjoinscons.sno=sc.snowheresc.con=c0212、查询成绩、查询成绩80分以上的学生的姓名、选的课程号和成绩,分以上的学生的姓名、选的课程号和成绩,并按成绩降序排列结果并按成绩降序排列结果selectsname,cno,gradefromstudentsjoinscons.sno=sc.snowheregrade80orderbygradedesc13、查询哪些学生没有选课,要求列出学号、姓名和所在系、查询哪些学生没有选课,要求列出学号、姓名和所在系selects.sno,sname,sdeptfromstudentsleftjoinscons.sno=oisnull14、查询与、查询与VB在同一学期开设的课程的课程名和开课学期在同一学期开设的课程的课程名和开课学期ame,c1.semesterfromcoursec1joincoursec2onc1.semester=ame=VBame!=VB15、查询与李勇年龄相同的学生的姓名、所在系和年龄、查询与李勇年龄相同的学生的姓名、所在系和年龄selects2.sname,s2.sdept,s2.sagefromstudents1joinstudents2ons1.sage=s2.sagewheres1.sname=李勇李勇ands2.sname!=李勇李勇16、查询计算机系年龄最小的、查询计算机系年龄最小的2名学生的姓名和年龄名学生的姓名和年龄selecttop2withtiessname,sagefromstudentwheresdept=计算机系计算机系orderbysageasc17、查询、查询VB考试成绩最高的前考试成绩最高的前2名学生的姓名、所在系和名学生的姓名、所在系和VB成绩,包括并列的情况成绩,包括并列的情况selecttop2withtiessname,sdept,gradefromstudentsjoinscons.sno=o=owherecname=VBorderbygradedesc18、查询选课门数最多的前、查询选课门数最多的前2名学生的学号和选课门数,包名学生的学号和选课门数,包括并列的情况括并列的情况selecttop2withtiessno,count(*)fromscgroupbysnoorderbycount(*)desc19、查询学生人数最多的系,列出系名和人数。、查询学生人数最多的系,列出系名和人数。selecttop1sdept,count(*)fromstudentgroupbysdeptorderbycount(*)desc20、用子查询实现如下查询:、用子查询实现如下查询:1)查询选修了)查询选修了”C01“课程的学生姓名和所课程的学生姓名和所在系在系selectsname,sdeptfromstudentwheresnoin(selectsnofromscwherecon=c01)2)查询数学系成绩)查询数学系成绩80分以上的学生的学号、分以上的学生的学号、姓名、选的课程号和成绩姓名、选的课程号和成绩selectsno,sname,cno,gradefromstudentjoinsconstudent.sno=sc.snowheresdept=数学系数学系andsnoin(selectsnofromscwheregrade80)20、3)查询计算机系考试成绩最高的学生的姓名)查询计算机系考试成绩最高的学生的姓名selectsnamefromstudentsjoinscons.sno=sc.snowheresdept=计算机系计算机系andgrade=(selectmax(grade)fromscjoinstudentsons.sno=sc.snowheresdept=计算机系计算机系)4)查询数据结构考试成绩最高的学生的姓名、所在)查询数据结构考试成绩最高的学生的姓名、所在系、性别和成绩系、性别和成绩selectsname,sdept,ssex,gradefromstudentsjoinscons.sno=o=owherecname=数据结构数据结构andgrade=(selectmax(grade)o=owherecname=数据结构数据结构)21、查询没有选修、查询没有选修VB课程的学生的姓名和所在系课程的学生的姓名和所在系selectsnamesdeptfromstudentsjoinscons.sno=o=owherecname!=VB22、查询计算机系没有选课的学生的姓名和所在系、查询计算机系没有选课的学生的姓名和所在系 selectsnamefromstudentsleftjoinscons.sno=sc.snoWheresdept=计算机系计算机系oisnull23、查询计算机系考试平均最低的学生的姓、查询计算机系考试平均最低的学生的姓名以及所选的课程名名以及所选的课程名selectsname,cnamefromstudentsjoinscons.sno=o=owheresdept=计算机系计算机系andsno=(selecttop1snofromscorderbyave(grade)asc)24、查询、查询1-5学期中选课人数最少的课程的课学期中选课人数最少的课程的课程名、开课学期和学分程名、开课学期和学分SELECTCname,Semester,CreditFROMCourseWHERE(CnoIN(SELECTTOP1WITHtiescnoFROMscGROUPBYcnoORDERBYCOUNT(*)ASC)AND(SemesterBETWEEN1AND5)25、createtabletest_t(col1int,col2char(10)notnull,col3char(10)insertintotest_t(col2)values(b1)insertintotest_t(col1,col2,col3)values(1,b2,c2)insertintotest_t(col1,col2)values(2,b3)26、删除考试成绩低于、删除考试成绩低于50分的学生的该门课程的选分的学生的该门课程的选课记录课记录deletefromscwheregrade60andsdept=计算机计算机系系29、删除、删除VB考试成绩最低的学生的考试成绩最低的学生的VB选课记录选课记录deletefromscjoinstudentsons.sno=o=owherecname=vbandgrade=(selectmin(grade)fromscjoinstudentsonsc.sno=s.snowherecname=vb)30、将第、将第2学期开设的所有课程的学分增加学期开设的所有课程的学分增加2分分updatecoursesetcredit=credit+2wheresemester=231、将、将VB课程的学分改为课程的学分改为3分分updatecoursesetcredit=credit+2wherecname=vb32、将计算机系学生的年龄增加、将计算机系学生的年龄增加1岁岁updatestudentsetsage=sage+1wheresdept=计算机系计算机系33、将信息系学生的、将信息系学生的“计算机文化学计算机文化学”课程的考试成课程的考试成绩加绩加5分分updatescsetgrade=grade+5wherecnoin(selectcnofromcoursewherecname=计算机系计算机系)andsnoin(selectsnofromstudentwheresdept=信息系信息系)34、将选课人数最少的课程的学分降低、将选课人数最少的课程的学分降低1分分updatecoursesetcredit=credit-1wherecno=(selecttop1cnofromscgroupbycnoorderbycount(*)asc)第六章作业9、1)在在student表上为表上为sname列建立一个聚集索引,索引列建立一个聚集索引,索引名为名为sldxcreateclusteredindexsldxonstudent(sname)2)在在course表上为表上为cname列建立一个唯一的非聚集索列建立一个唯一的非聚集索引,索引名为引,索引名为cnidxcreateuniquenonclusteredindexcnidxoncourse(cname)3)在在SC表上为表上为SNO和和CNO建立一个组合的聚集索引,建立一个组合的聚集索引,索引名为索引名为snocnoidxCreateclusteredindexsnocnoidxonsc(sno,cno)4)删除删除SNAME列上建立的列上建立的sldx索引索引Dropindexsldx12、1)查询学生的学号、姓名、所在系、课程名、课程号、课程学分查询学生的学号、姓名、所在系、课程名、课程号、课程学分createviewv1asselects.sno,sdept,cno,cname,creditfromstudentsjoinscons.sno=o=o2)查询学生的学号、姓名、选修的课程名和考试成绩查询学生的学号、姓名、选修的课程名和考试成绩createviewv2asselects.sno,sname,cname,gradefromstudentsjoinscons.sno=o=o3)统计每个学生的选课门数,要求列出学生学号和选课门数统计每个学生的选课门数,要求列出学生学号和选课门数createviewv3asselectsno,count(*)astotalfromscgroupbysno4)统计每个学生的选课总学分,要求列出学生学号和总学分(说明:考试成统计每个学生的选课总学分,要求列出学生学号和总学分(说明:考试成绩大于等于绩大于等于60分才能获得此门课程的学分)分才能获得此门课程的学分)createviewv4asselectsno,sum(credit)total_o=owheregrade=60groupbysno13、1)查询考试成绩大于等于)查询考试成绩大于等于90分得学生的姓名、课程名和成绩分得学生的姓名、课程名和成绩selectsname,cname,gradefromv2wheregrade=902)查询选课门数超过查询选课门数超过3门的学生的学号和选课门数门的学生的学号和选课门数select*fromv3wheretotal33)查询计算机系选课门数超过查询计算机系选课门数超过3门的学生的姓名和选课门数门的学生的姓名和选课门数selectsname,totalfromv3joinstudentsonv3.sno=s.sno4)查询修课总学分超过查询修课总学分超过10分的学生的学号、姓名、所在系和修分的学生的学号、姓名、所在系和修课总学分课总学分selectv4.sno,sname,sdept,total_creditfromv4joinstudentsons.sno=v4.snowheretotal_credit105)查询年龄大于等于查询年龄大于等于20的学生中,修课总学分超过的学生中,修课总学分超过10分的学生分的学生的姓名、年龄、所在系和修课总学分的姓名、年龄、所在系和修课总学分selectsname,sage,sdept,total_creditfromv4joinstudentsonv4.sno=s.snowheresage=20andtotal_credit=1014、修改视图、修改视图v4,使其查询每个学生的学号、总学分,使其查询每个学生的学号、总学分和总的选课门数和总的选课门数alterviewv4asselectsno,sum(credit),count(*)o=ogroupbysno第七章作业6、关系模式:学生修课(学号,姓名,所在系,性别,、关系模式:学生修课(学号,姓名,所在系,性别,课程号,课程名,学分,成绩)课程号,课程名,学分,成绩)语义:一个学生可以选多门课程,一门课程可以被多语义:一个学生可以选多门课程,一门课程可以被多名学生选。一个学生有唯一的所在系,每门课程有名学生选。一个学生有唯一的所在系,每门课程有唯一的课程名和学分唯一的课程名和学分答:候选码为(学号,课程号),同时也是此关系模答:候选码为(学号,课程号),同时也是此关系模式的主键式的主键分解:分解:学生表(学生表(学号学号,姓名,所在系,性别),姓名,所在系,性别)课程表(课程表(课程号课程号,课程名,学分),课程名,学分)选课表(选课表(学号,课程号学号,课程号,成绩),成绩)7、关系模式:学生(学号,姓名,所在系,班号,班、关系模式:学生(学号,姓名,所在系,班号,班主任,系主任)主任,系主任)语义:一个学生只在一个系的一个班学习,一个系只语义:一个学生只在一个系的一个班学习,一个系只有一个系主任,一个班只有一名班主任,一个系可有一个系主任,一个班只有一名班主任,一个系可以有多个班。以有多个班。答:候选码为学号,同时也是此关系模式的主键答:候选码为学号,同时也是此关系模式的主键分解:分解:学生表(学生表(学号学号,姓名,所在系,班号),姓名,所在系,班号)班级表(班级表(班号班号,班主任),班主任)选课表(选课表(所在系所在系,系主任),系主任)8、关系模式:教师授课(课程号,课程名,学分,授、关系模式:教师授课(课程号,课程名,学分,授课教师号,教师名,授课时数)课教师号,教师名,授课时数)语义:一名课程(有课程号决定)有确定的课程名和语义:一名课程(有课程号决定)有确定的课程名和学分,每名教师(有教师号决定)有确定的教师名,学分,每名教师(有教师号决定)有确定的教师名,每门课程可以有多名教师讲授,每名教师也可以讲每门课程可以有多名教师讲授,每名教师也可以讲授多门课程,每名教师对每门课程有确定的授课时授多门课程,每名教师对每门课程有确定的授课时数数答:候选码为(课程号,授课教师号),同时也是此答:候选码为(课程号,授课教师号),同时也是此关系模式的主键关系模式的主键分解:分解:课程表(课程表(课程号课程号,课程名,学分),课程名,学分)教师表(教师表(教师号教师号,教师名),教师名)授课表(授课表(课程号,教师号课程号,教师号,授课时数),授课时数)