数据库原理实验报告.doc_第1页
数据库原理实验报告.doc_第2页
数据库原理实验报告.doc_第3页
数据库原理实验报告.doc_第4页
数据库原理实验报告.doc_第5页
已阅读5页,还剩17页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

数据库原理实验报告学号: 姓名: 班级: 计科10-6 指导教师: 中国矿业大学计算机科学与技术学院 年 月数据库原理教师成绩评定表评定成绩的依据:基础理论及基本技能的掌握独立解决实际问题的能力;研究内容的理论依据和技术方法;取得的主要成果工作态度及工作量;成绩采用优良中差四个等级评定成绩表实验序号实验成绩指导教师日期实验一实验二实验一:sql数据定义功能一、实验内容及要求1. 使用sql语句建立学生管理系统相关的表,同时完善各表的相关完整性约束。其中带有下划线的为主码 学院(学院代码,学院名称) create table 学院(学院代码 char(8) primary key,学院名称 char(8); 学生(学号,姓名,性别,学院代码) ,学院代码为外码create table 学生(学号 char(8) not null unique,姓名 char(8),性别 char(8),学院代码 char(8),primary key(学号),foreign key(学院代码) references 学院(学院代码); 教师(教师号,教师姓名,学院代码),学院代码为外码create table 教师(教师号 char(8) primary key,教师姓名 char(8),学院代码 char(8),foreign key(学院代码) references 学院(学院代码); 课程(课程号,课程名,学时)create table 课程(课程号 char(8) primary key,课程名 char(8),学时 char(8); 学习(学号,课程号,成绩),学号为外码,课程号为外码create table 学习(学号 char(8),课程号 char(8),成绩 char(8),primary key(学号,课程号),foreign key(学号) references 学生(学号),foreign key(课程号) references 课程(课程号); 开课(教师号,课程号),教师号为外码,课程号为外码create table 开课(教师号 char(8),课程号 char(8),primary key(教师号,课程号),foreign key(教师号) references 教师(教师号),foreign key(课程号) references 课程(课程号);2. 对各表进行增加、删除、修改属性操作添加操作:对学生表添加出生日期字段,和家庭地址字段,教师表增加性别字段,出生日期字段,对课程表增加先修课程字段,并且先修课程为本关系外码。可以在access图形界面中用鼠标点击单元格添加新字段右键选择插入列新建一个列,同时也可以用sql建立表例如alter table 学生 add 出生日期 char(8);alter table 学生 add 地址 char(20);alter table 教师 add 性别 char(8);alter table 教师 add 出生日期 date;alter table 课程 add 先修课程 char(8) ;alter table 课程 foreign key(先修课程) references 课程(先修课程);删除操作:删除学生表家庭地址字段,删除教师表出生日期字段alter table 学生 drop column 地址;alter table 教师 drop column出生日期;修改操作:修改学生姓名字段,该字段值不允许取空值alter table 学生 alter column 姓名 char(20) not null unique;3. 建立索引为学生表在学生姓名上建立名为sname-index 的索引,在学院代码字段上建立名为dept-index,降序。create unique index sname_index on 学生(姓名);create unique index dept_index on 学院(学院代码 desc)4. 利用access 2003 /2007完善各表的数据内容数据可以由所建表中直接输入,也可以由 insert into 学生 values(. )插入例如在学生表中插入一组数据insert into 学院 values (101,计算机 );5. 建立tempstudent表,表模式自行定义,之后将其删除建立tempstudent表create table tempstudent(sno char(8),sname char(8);删除表可以由语句 drop table tempstudent cascade; 执行二、实验目的熟练掌握sql的各种数据定义功能,包括1.定义表的功能,包括主码和外码的定义2.修改表的定义功能,包括增加属性,删除属性,修改属性类型4.建立和删除索引操作,理解索引的作用5.删除表功能三、实验步骤及运行结果四、实验体会通过本次实验我了解到了数据库基本的建表方法,明白了如何去对一个表进行插入修改删除和建立索引,掌握了基本的建表方法实验二:练习sql数据操纵功能一、实验内容及要求建表截图学院表学生表教师表学习表开课表课程表1求选修了某个老师上课的学生,成绩在90分以上的姓名、课程名称和成绩; select 姓名, 课程名, 成绩from 学生, 教师, 学习, 课程, 开课where 学生.学号=学习.学号 and 学习.课程号=课程.课程号 and 课程.课程号= 开课.课程号 and 开课.教师号=教师.教师号 and 教师姓名=张强 and 成绩 90;2求选修了某个老师所授全部课程的学生姓名和学院名称; select 姓名,学院名称from 学生,学院where 学生.学院代码=学生.学院代码and 姓名 in(select distinct 姓名from 学生,学院where 学号 in(select 学号from 学习where 课程号 in(select 课程号from 开课where 教师号 in(select 教师号from 教师where 教师姓名=王强)and 学生.学院代码=学院.学院代码;3求没有选修某门课程的学生学号和姓名; select distinct 学生.学号,姓名from 学生,课程,学习where 学生.学号=学习.学号and 学习.课程号=课程.课程号and 学生.学号 not in (select 学生.学号from 学生,课程,学习where 学生.学号=学习.学号and 学习.课程号=课程.课程号and 课程名=数据结构); 4求至少选修了两门课程的学生学号; select 学号,count(课程号) as 选课数from 学习where 学号 between 08101and 08108group by 学号having count(课程号)=2;5求某门课程不及格学生姓名和考试成绩 select 姓名,成绩from 学生,学习,课程where 学生.学号=学习.学号and 学习.课程号=课程.课程号and 课程名=数据库and 成绩=2);16自行提出查询要求,内容包括并运算、差运算、交运算、笛卡儿积运算、连接运算、自然连接运算以及复杂统计表。16查询选修了张强老师和王慧老师却没有选修王鹏老师课程的学生的学号和姓名和成绩,并且按成绩由高到低排序.select 学生.学号,姓名,成绩from 学生,学习where 学生.学号=学习.学号and 学习.学号 in(select 学号from 开课,教师,学习where 学习.课程号=开课.课程号and 开课.教师号=教师.教师号and 教师姓名=张强and 学号 in(select 学号from 开课,教师,学习where 学习.课程号=开课.课程号and 开课.教师号=教师.教师号and 教师姓名=王慧and 学号 not in(select 学号from 开课,教师,学习where 学习.课程号=开课.课程号and 开课.教师号=教师.教师号and 教师姓名=王强)order by 成绩 desc; 二、实验目的使用sql语句进行各种查询1、熟练掌握单表查询,包括 (1) 选择表中的若干列(投影) (2) 选择表中的若干元组(选择) (3) 对查询结果排序 (4) 使用集函数 (5) 对查询结果分组2、熟练掌握复杂查询,包括1) 等值与非等值连接查询 2) 自身连接:一个表与其自己进行连接。3) 外连接查询4) 复合条件连接:where 子句中可以有多个连接条件。3、熟练掌握嵌套查询,包括1) 带有in谓词的子查询2) 带有比较运算符的子查询(子查询一定要跟在比较符之后)3) 带有any或all谓

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论