资源描述:
《数据库实验sql语句》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、实验二查询操作一、实验目的和要求1、掌握通过SQL语句对数据库进行查询操作的方法。二、实验步骤1、建立数据库dbtest2、根据附件里的SQL语句建立student表、course表、sc表,并填入数据。3、完成下列查询操作。1)查询学分为2的课程名称。2)查询所有男生的名单。3)查询所有成绩及格的学生学号。4)查询成绩在80-90之间(包含两端)学生学号和课程号。5)查询所有姓“刘”的同学的名单。6)某些学生选修课程后没有参加考试,所以有选课记录,但没有考试成绩。查询缺少成绩的学生的学号和相应的课程号。7)查询选修了3号课程,而且成绩大于80分的学生学号,查询结果按分数降序排列。
2、8)查询有多少人选修了课程。9)查询2号课程的最高分。10)查询2号课程的平均分。11)统计所有的男生人数和女生人数。12)查询学生的姓名和他/她选修的课程名称。1)查询学生的姓名、他/她选修的课程名称和成绩。2)查询选修了课程名为“信息系统”的学生学号、姓名、成绩。3)查询每个学生超过他所选选修课的平均成绩的课程号。4)每门课程所对应的平均成绩。5)建立一张包含学生所有信息的视图student_all6)在student_all视图上查询查询学生的姓名、他/她选修的课程名称和成绩。附件:CREATETABLEStudent(SnoCHAR(9)PRIMARYKEY,/*列级完整性
3、约束条件*/SnameCHAR(20)UNIQUE,/*Sname取唯一值*/SsexCHAR(2),SageSMALLINT,SdeptCHAR(20));insertintostudentvalues('200215121','李勇','男',20,'CS');insertintostudentvalues('200215122','刘晨','女',19,'CS');insertintostudentvalues('200215123','王敏','女',18,'MA');insertintostudentvalues('200215125','张立','男',19,'IS')
4、;insertintostudentvalues('200215126','欧阳夏丹','女',18,'IS');CREATETABLECourse(CnoCHAR(4)PRIMARYKEY,CnameCHAR(40),CpnoCHAR(4),CcreditSMALLINT,FOREIGNKEY(Cpno)REFERENCESCourse(Cno));InsertintoCourseValues('2','数学',null,2);InsertintoCourseValues('6','数据处理',null,2);InsertintoCourseValues('7','语言','6'
5、,4);InsertintoCourseValues('4','操作系统','4',3);InsertintoCourseValues('5','数据结构','7',4);InsertintoCourseValues('1','数据库','5',4);InsertintoCourseValues('3','信息系统','1',4);InsertintoCourseValues('8','db_test','1',4);CREATETABLESC(SnoCHAR(9),CnoCHAR(4),GradeSMALLINT,PRIMARYKEY(Sno,Cno),/*主码由两个属性构成,必
6、须作为表级完整性进行定义*/FOREIGNKEY(Sno)REFERENCESStudent(Sno),/*表级完整性约束条件,Sno是外码,被参照表是Student*/FOREIGNKEY(Cno)REFERENCESCourse(Cno)/*表级完整性约束条件,Cno是外码,被参照表是Course*/);insertintoscvalues('200215121','1',92);insertintoscvalues('200215121','2',85);insertintoscvalues('200215121','3',88);insertintoscvalues('20
7、0215122','2',90);insertintoscvalues('200215122','3',80);insertintoscvalues('200215123','3',null);/*1*/selectcnamefromcoursewhereccredit=2/*2*/selectsnamefromstudentwheressex='男'/*3*/selectdistinctsnofromscwheregrade>=60/*4*/selectsno,cn