您好,欢迎访问三七文档
实验三单表查询一、实验目的掌握简单SQL查询语句的应用,包括like、top、orderby、compute、聚集函数的应用。二、实验内容1、基本查询(1)查询学生表中全体学生的全部信息。select*fromStudent(2)检索全体学生的学号、姓名。selectSno,SnamefromStudent2、查询时改变列标题的显示检索全体学生的学号、姓名、家庭地址信息,并分别加上“学生”、“学号”、“家庭地址”的别名信息。selectSnameas学生,Snoas学号,Home_addras家庭地址fromStudent3、条件查询(1)查询成绩大于80分的学生的学号及课程号、成绩。selectSno,Cno,GradefromSCwhereGrade80(2)查询成绩介于75~80分的学生的学号及课程号、成绩。selectSno,Cno,GradefromSCwhereGradebetween75and80(3)查询选修了课程号为“002”,且成绩大于80的学生的学号。selectSnofromSCwhereGrade80andCno='002'(4)某些学生选修某门课程后没有参加考试,所以有选课记录,但没有考试成绩,下面我们来查一下缺少成绩的学生的学号和相应的课程号。selectSno,CnofromSCwhereGradeisnull4、基于IN子句的数据查询从课程表中查询出“高数”、“C语言程序设计”的所有信息。select*fromCoursewhereCnamein('高数','c语言程序设计')5、基于BETWEEN。。。。AND子句的数据查询查询所有成绩在70-80之间的学生选课信息。(between···and为闭区间)select*fromSCwhereGradebetween70and806、基于Like子句的查询(1)从学生表中分别检索出姓张的所有同学的资料;检索名字的第二个字是“红”或“虹”的所有同学的资料。select*fromStudentwhereSnameLIKE'张%'orSnameLIKE'_红%'orSnameLIKE'_虹%'(2)查询课程名为Visual_Basic的课程的学分。(提示:使用ESCAPE短语)selectCreditfromCoursewhereCnameLIKE'Visual\_Basic'ESCAPE'\'7、使用top关键字查询(1)从选课表中检索出前3个课程信息。selectTop3*fromCourse(2)从选课表中检索出前面20%的课程信息。selectTop20PERCENT*fromCourse8、消除重复行检索出学生已选课程的课程号,要求显示的课程号不重复。selectdistinctCnofromCourse9、查询经过计算的值。查询全体学生的姓名及其年龄(提示:利用系统函数getdate())selectSnameas姓名,YEAR(getdate())-YEAR(Birth)as年龄fromStudent10、使用ORDERBY语句对查询的结果进行排序(1)显示所有学生的基本信息,按班号排列,班号相同则再按学号排列。select*fromStudentOrderbyClassno,Sno(2)查询全体学生的姓名及其年龄,并按学生的年龄的降序排列。selectSnameas姓名,year(getdate())-year(Birth)as年龄fromStudentOrderby'年龄'desc11、使用聚合函数(1)查询学生总人数。selectcount(distinctSno)as学生总人数fromStudent(2)计算“002”号课程的学生平均成绩、最高分、最低分。selectAVG(Grade)as平均分,MAX(Grade)as最高分,MIN(Grade)as最低分fromSCWhereCno='002'12、使用Group子句进行查询(1)查询各班级学生总人数。selectClassnoas班级,COUNT(*)as学生人数fromStudentGroupbyClassno(2)汇总总分大于150分的学生的学号及总成绩。selectSnoas学号,Sum(Grade)as总成绩fromSCGroupbySnoHavingSum(Grade)150(3)查询各个课程号相应的选课人数。selectCnoas课程号,Count(*)as学生人数fromSCGroupbyCno13、使用Compute和computeby子句进行查询(1)汇总每个学生的学号及总成绩。selectSno学号,Grade成绩fromSCOrderbySnoComputeSum(Grade)bySno(2)按学号汇总出每个学生的学号及总成绩、最高分、最低分,及所有学生总成绩。selectsno学号,grade成绩fromSCorderbysnocomputesum(grade),MAX(grade),MIN(grade)bysnoselectsno学号,grade成绩fromSCorderbysnocomputesum(grade)观察使用Compute子句和Computeby子句执行结果有何不同?答:Computeby子句执行后结果以by之后的关键词进行排序。
本文标题:3实验三-单表查询
链接地址:https://www.777doc.com/doc-4514790 .html