学生选课系统的数据库设计与实现_第1页
学生选课系统的数据库设计与实现_第2页
学生选课系统的数据库设计与实现_第3页
学生选课系统的数据库设计与实现_第4页
学生选课系统的数据库设计与实现_第5页
已阅读5页,还剩6页未读 继续免费阅读

下载本文档

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

文档简介

1、精选优质文档-倾情为你奉上数据库系统概论实验报告学 号:姓 名:提交日期:2010-12-15成 绩:专心-专注-专业【实验名称】学生选课系统的数据库设计与实现【实验内容】1、熟悉数据库设计方法;2、熟悉E-R图到关系模式的转换;3、掌握SQL Server 2005数据库的创建SQL语句,理解数据库文件组、文件逻辑名和物理名称的具体含义;4、掌握SQL Server 2005 中用SQL语句建立数据库表,设置数据库完整性约束;5、掌握用SQL Server 2005 建立表的关系图,清楚的表示各表之间的联系。【实验步骤】一、 数据库的逻辑设计图(一)班级、学生、课程实体类型及联系型的ER图图

2、(二)班级实体的分ER图图(三)课程实体的分ER图图(四)学生实体的ER图将上述的E-R图转换为关系模型,关系的主键用下横线标出。学生(学号,姓名,性别,年龄,班级号)课程(课程号,课程名,课时 ,学分)班级(班级号,班级名,人数,专业)选课(课程号学号,成绩)二、 数据库的物理设计1 建表语句:本数据库共创建了四张表,其建表语句如下 1班级表create table class(classNo int not null primary key,className char(20),sdept char(20),number int)2学生表create table student(stude

3、ntNo int not null primary key,studentName char(20),sex char(20),age int,classNo int)3.课程表create table course(courseNo int not null primary key,courseName char(20),grade int)4选课表create table choice(studentNo int,courseNo int。result int,primary key(studentNo,courseNo)2说明外码语句alter table choiceadd forei

4、gn key (studentNo) references student(studentNo), foreign key (courseNo) references course(courseNo)alter table studentadd foreign key (classNo) references class(classNo)3记录插入语句:(1)class表:insert class values (40801,'yyy','os',35)insert class values (40802,'xx','ad',45

5、)insert class values (40803,'rr','cs',36)insert class values (40804,'yy','os',35)insert class values (40805,'ee','ry',78)insert class values (40806,'yyy','os',35)insert class values (40807,'xg','ad',45)insert class value

6、s (40808,'ry','cs',36)insert class values (40809,'yd','os',65)insert class values (,'eg','ry',48)(2)student表:insert student values(10001,'aa','f',23,40801)insert student values(10002,'df','f',23,40802)insert student valu

7、es(10003,'adf','f',22,40802)insert student values(10004,'gh','m',23,40803)insert student values(10005,'dc','f',24,40804)insert student values(10006,'sd','m',23,40802)insert student values(10007,'dfc','f',23,40803)insert

8、student values(10008,'xc','m',25,40805)insert student values(10009,'sd','f',23,40806)insert student values(,'cv','f',27,40806)(3)course表:insert course values(1,'operating',48,8)insert course values(2,'computer',24,4)insert course values

9、(3,'music',56,12)insert course values(4,'compile',48,8)insert course values(5,'oracle',32,6)insert course values(6,'sql',48,8)(4)choice表:insert choice values(10001,1,80)insert choice values(10001,2,85)insert choice values(10002,3,86)insert choice values(10002,5,45)ins

10、ert choice values(10003,1,80)insert choice values(10004,2,87)insert choice values(10004,6,89)insert choice values(10005,1,90)insert choice values(10005,4,100)insert choice values(10006,1,60)insert choice values(10006,3,49)insert choice values(10007,5,70)insert choice values(10008,1,70)insert choice

11、values(10008,6,78)insert choice values(10009,2,80)insert choice values(,3,78)insert choice values(,1,80)insert choice values(,2,78)insert choice values(,4,89)insert choice values(,5,45)4、查询记录:1.选择输出学号、姓名满足性别为女,年龄小于25select studentNo,studentNamefrom studentwhere sex='f'and age<255.创建视图创建视图

12、 :选择班级人数>50的班级输出其班级号和人数create view Numasselect classNo,numberfrom classwhere number>50查询语句select * from Num6.插入数据插入数据:插入student表中一个学生,学生名为newstudent,性别为女,年龄34,班级号为40806insert student values(,'newstudent','f',24,40806)三、 利用SQL Server 2005的Management Studio来创建表的关系图,创建好的关系图如下所示:四

13、实验体会通过这次实验,让我对sql server2005的使用更加熟悉了,同时也加深了我对课本上数据库知识的理解,这次实验可以说是我第一次完成的一个整体的数据库实验。此次实验中,我完成了从概念设计到逻辑设计,也就是完成了ER图的设计并完成了向关系模型的转换,完成了数据库的建立、表的建立、视图的创建,最后还完成了表之间的关系图。一个数据库的创建首先要对客户的需求进行充分的分析,找出创建数据库所需的实体和实体间的关系画出E-R 图,确定要创建的表的数量和每张表的属性、主键和外键。在动手实验的过程中我遇到很多困难,比如如何删除表中的数据但不保留到日志文件中,数据的不普遍性所造成的查询等操作的空表等等

14、,但是正是这些问题才让我学到了更多,同时也享受到了解决问题后的喜悦。更重要的是,我对数据库产生了浓厚的兴趣,相信以后会把学到的东西应用到实践中去的。五 附录(SQL语句)-班级表create table class(classNo int not null primary key,className char(20),sdept char(20),number int)-学生表create table student(studentNo int not null primary key,studentName char(20),sex char(20),age int,classNo int)

15、create table course(courseNo int not null primary key,courseName char(20),courseTime int,grade int)create table choice(studentNo int,courseNo int,result int,primary key(studentNo,courseNo)alter table choiceadd foreign key (studentNo) references student(studentNo), foreign key (courseNo) references c

16、ourse(courseNo)alter table studentadd foreign key (classNo) references class(classNo)insert class values (40801,'yyy','os',35)insert class values (40802,'xx','ad',45)insert class values (40803,'rr','cs',36)insert class values (40804,'yy','o

17、s',35)insert class values (40805,'ee','ry',78)insert class values (40806,'yyy','os',35)insert class values (40807,'xg','ad',45)insert class values (40808,'ry','cs',36)insert class values (40809,'yd','os',65)insert cl

18、ass values (,'eg','ry',48)select * from studentinsert student values(10001,'aa','f',23,40801)insert student values(10002,'df','f',23,40802)insert student values(10003,'adf','f',22,40802)insert student values(10004,'gh','m

19、9;,23,40803)insert student values(10005,'dc','f',24,40804)insert student values(10006,'sd','m',23,40802)insert student values(10007,'dfc','f',23,40803)insert student values(10008,'xc','m',25,40805)insert student values(10009,'sd'

20、;,'f',23,40806)insert student values(,'cv','f',27,40806)insert course values(1,'operating',48,8)insert course values(2,'computer',24,4)insert course values(3,'music',56,12)insert course values(4,'compile',48,8)insert course values(5,'oracle',32,6)insert course values(6,'sql',48,8)insert choice values(10001,1,80)insert choice values(10001,2,85)insert choice values(10002,3,86)insert choice values(10002,5,45)insert choice values(10003,1,80)insert choice values(10004,2,87)insert choice values(10004,6,89)insert choice v

温馨提示

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

评论

0/150

提交评论