1、数据库设计相关要求与示例第一部分相关要求1、目的和意义通过课程设计,使学生掌握数据库的基本概念,结合实际的问题和设计,巩 固课堂教学内容,使学生掌握数据库系统的基本概念、 原理和技术,将理论与实 际相结合,应用现有的数据建模工具,规范、科学地完成一个小型数据库的设计。2、具体要求课程设计以小组为单位,一般 23人为一组,第11周之前各组确定选题。 要求学生根据题目的需求描述,进行实际调研,提出完整的需求分析报告,建立 概念模型、物理模型,在物理模型中根据需要添加必要的约束、视图等数据库对 象,最后生成创建数据库的脚本。小组成员之间,分工明确,密切合作,培养良 好的互相帮助和团队协作精神。各组要
2、按时完成规定的工作,不得弄虚作假,不 准抄袭他人内容,否则成绩以不及格计。3、选题原则课程设计题目以选用学生相对比较熟悉的业务模型为宜,要求通过本次设计环节,能较好地巩固数据库的基本概念、基本原理、关系数据库的设计理论、设 计方法等主要相关知识点,针对实际问题设计概念模型,并应用现有的工具完成 小型数据库的设计。具体选题可参考下文表格中的题目,也可自行选题。4、评分标准评分标准:(以百分制为例)(1) 85-100:完成题目中的所有内容,功能完善,文档详细,数据库设计 合理。(2) 70-84:完成题目中的大部分内容,功能基本完善,文档较详细,数据 库设计基本合理。(3) 60-69:基本完成
3、上述内容,只有基本功能文档。(4) 0-59:未按时完成上述内容,或者抄袭(雷同者全部为不及格)。5、参考题目学生学籍信息管理系统通讯录管理器客户信息管理系统学生成绩智能管理信息系统物资管理系统员工培训管理系统酒店管理系统汽车租借信息系统物资管理系统企业工资管理系统产品质量管理系统宾馆管理系统住院收费信息管理系统火车卧铺订票管理系统房产销售管理系统书刊租借信息管理系统选修课管理系统职工管理系统学生缴费注册管理系统高校科研管理系统毕业生管理系统维修信息管理系统订单生成系统进销存管理系统工资信息管理系统考勤信息管理系统饭店餐饮收费信息系统图书库存管理系统出版社信息管理系统医药连锁店系统电脑书店信息
4、管理系统旅行社综合管理系统物流配送中心管理系统地区图书馆管理系统水电收费管理系统电信收费管理系统电信产品发布网站教材管理系统学生宿舍管理系统6、撰写设计报告第16周之前提交报告打印版和电子版第二部分数据库设计报告模板XX管理信息系统一、需求分析分析清楚系统用户、功能、涉及的数据二、概念结构设计绘制E-R图确定实体、属性和联系三、逻辑结构设计将E-R图转换为数据模型;关系规范化;设计视图(根据需要确定) 四、数据库物理结构设计对各表进行详细设计,包括字段名、数据类型、长度、是否为空、默认值、 索引、约束五、数据库实施编写SQL代码创建数据库、数据表、加载数据(所有数据表中的记录总数 不低于50条
5、)。六、总结说明小组成员分工情况以及本次课程设计的收获和体会第三部分 设计报告示例 (仅供参考)以综合教务系统为例, 说明数据库应用系统的设计过程。 本系统的分析和设计过程主要包括:需求分析;概念结构设计;逻辑结构设计等。本例以系统分析和数据库设计为主,没有给出操作界面设计。综合教务系统一、需求分析1、系统目标:实现一个计算机综合教务管理系统,完成班级信息管理,学生信息管理,课程信息管理和学生选课管理等功能。2、系统功能需求:本系统的用户分为超级用户和普通用户两类,超级用户负责系统维护,包括对班级信息,学生个人信息,课程信息的录入,修改,查询,删除等。普通用户即选课学生则只具有为自己选课的权限
6、。( 1) 功能划分用户通过身份验证后进入主界面。主界面为超级用户提供 6 项选择:学生信息管理,课程信息管理,班级信息管理,选课,口令修改和退出系统。普通用户有 4 项功能选择:选课,课程查询,口令修改和退出系统。( 2) 功能描述班级信息管理给出所有班级的列表, 超级用户可以实现增加, 修改, 查找, 删除班级信息,维护指定班级所有学生信息, 为指定班级设定必修课和选课学分限制等功能。 在维护指定班级学生信息功能中,超级用户可以实现增加,修改,删除学生信息,察看某一学生选课情况, 为学生更改口令等功能。 在指定班级必修课功能中, 以课表形式列出班级所有必修课的课程信息, 实现为一个班级增加
7、或删除必修课的功能。学生信息管理给出所有学生的列表,超级用户可以增加,修改,删除,查找学生信息,察看某个学生选课情况, 为学生修改口令等功能。 本项功能与班级信息维护功能中的维护指定班级学生信息功能相似, 不同的是本项功能中将列出所有班级的所有学生信息。课程信息管理用于添加,修改,删除课程纪录,查看某门课的选课情况,查询指定的课程信息。选课以课表的形式列出学生选课情况, 学生可以为自己选修或者退选课程, 而超 级用户可以为任何学生选修或者退选课程。每个班级都有选课的学分限制,不允 许学生选择课程的总学分超过所在班级的选课最大学分限制, 而当退出选课功能 时,如果选取课程总学分未达到所在班级选课
8、最小学分限制则给出警告信息 (学 生可以多次进入选课界面进行选课)。修改口令用户输入原口令,并且两次输入新口令一致后,系统即用新口令代替旧口令。 退出系统当用户退出系统时,如果选取的课程总学分未达到所在班级选课最小学分限 制,则给出警告信息。3、开发工具(可略)该综合教务系统的数据库采用了 Microsoft的SQL Server2005企业版,前 台应用程序采用了 AS喻写,提供了 Web#面方便学生从网上使用。由于采用了 ADO据库接口,因此很容易修改为支持 ORACLESYBASE DB2等数据库,该系 统的结构为B/S结构,即浏览器/服务器结构。二、概念结构设计1、系统概念模型图1选课
9、系统概念模型 E-R图(注:本例中上课时间可以抽象成实体,也可以抽象成属性。 )2、详细说明( 1)系统涉及的实体集班级实体集:具有属性班级名称和选课学分限制。学生实体集:具有属性学号、姓名、性别和生日。课程实体集:具有属性课程号、课程名、学分、授课教师、接纳人数。上课时间实体集:具有属性时间。( 2)系统涉及的联系一个班级可以有多个学生,一个学生只能属于一个班级,所以班级和学生之间的联系为 1: M 的联系。一个班级可以有多门必修课程,一门课程是多个班级的必修课,所以班级和课程之间的必修联系是M : N 的联系。一个学生课以选修多门课程,一门课程可以被多个学生选修,所以学生和课程之间的联系是
10、M : N 的联系。一门课程可以有多个上课时间,同一时间内可以有多门课程在上课,所以课程和上课时间的联系是M : N 的联系。三、逻辑结构设计将 E-R 模型转换为关系模式( 1)班级实体集可以转换为关系CLASS ( CLASSNAME,MAXCREDIT,MINCREDIT )CLASSNAME 表 示 班 级 名 称 , MAXCREDIT 表 示 最 大 学 分 限 制 , MINCREDIT 表示最小学分限制。( 2)学生实体集可以转换为关系STUDENT (STUDENTID , NAME , SEX , BIRTHDAY )STUDENTID 表示学号, NAME 表示姓名, S
11、EX 表示性别, BIRTHDAY 表 示生日( 3)课程实体可以转换为关系COURSE( COURSEID, COURSENAME, CREDIT, TEACHER, ACCEPTION )COURSEID 表示课程号,COURSENAM 表示课程名,CREDIT 表示学分,TEACHER 表示授课教师, ACCEPTION 表示接纳人数。( 4)班级和学生之间的联系是1: M 的联系,所以没有必要为其建立一个关系,可以通过扩展学生关系来表示。STUDENT(STUDENTID , NAME , SEX , BIRTHDAY , CLASSNAME) CLASSNAME 表示学生所在班级名。
12、(5)班级和课程之间的必修联系可以转换为关系CLASSCOURSE(CLASSNAME , COURSEID)CLASSNAME表示班级名称,COURSEID表示课程号。(6)学生和课程之间的选修联系可以转化为关系STUDENTCOUSE(STUDENTID, COURSEID , GRADE)STUDENTID表示学号,COURSEID表示课程号,GRADE表示成绩(7)课程和上课之间的联系可以转化为关系COURSETIME(COURSEID , TIME)COURSEID表示课程号,TIME表示上课时间。(注:若将上课时间抽象成属性,则不必有关系(7)0)四、数据库物理结构设计1、把关系模
13、型转化为表结构(1)班级信息表(class):包含所有的班级信息。表1-班级信息表结构域名含义数据类型例子备注CLASSNAME班级名称字符类型121131001主码MAXCREDIT最大学分限制数值类型30MINCREDIT最小学分限制数值类型20(2)学生信息表(student):包含所有学生的个人信息表2-学生信息表结构域名含义数据类型例子备注STUDENTID学号字符类型1211310015主码NAME姓名字符类型王强SEX性别字符类型男BIRTHDAY生日日期类型95/07/15CLASSNAME班级名称字符类型121131001外码(3)课程信息表(course):包含所有课程信息
14、表3-课程信息表结构域名含义数据类型例子备注COURSEID球杠勺字符类型000001主码COURSENAME课程名称字符类型数值分析CREDIT学分数值类型4TEACHER任课教师字符类型刘强ACCEPTION接纳人数数值类型30(4)班级必修课表(classcourse):包含所有班级的必修课信息表4-班级必修课表结构域名含义数据类型例子备注CLASSNAME班级名称字符类型121131001外码COURSEID球杠勺字符类型000001外码(5)学生选课表(studentcourse):包含所有学生的选课信息表5-学生选课表结构域名含义数据类型例子备注STUDENTID学号字符类型121
15、1310015外码COURSEID球杠勺字符类型000001外码GRADE成绩数值类型85(6)上课时间表(coursetime):包含所有课程的上课时间表6-上课时间表结构域名含义数据类型例子备注COURSEID球杠勺字符类型000001外码COURSETIME上课时间数值类型21表示星期2第1节注:COURSETIME是一个整数,整除10的商表示星期几上课,余数表示当天的第几节 课。(7)用户账号表(user):包含所有用户的账号和口令信息表7-用户账号表结构域名含义数据类型例子备注USERID用户账号字符类型ADMINUSERPASSWD用户密码字符类型ADMINUSERAUTH用户权限
16、数值类型0STUDENTID用户学号字符类型1211310015注:USERAUTH用0, 1表示用户权限,0表示管理员,1表示普通用户。其中普通用 户的STUDENTID为学生的学号。2、实现数据完整性可以通过各种约束,缺省值,规则和触发器实现数据的完整性。由于教务系 统的重要性,以及各个数据之间的复杂相关性,保证数据的完整性显得更为重要。 不能让用户随意进行删除、修改数据。(1) CHEC的束保证最大限选学分要大于最小限选学分。(2)各种外码约束保证数据的完整性,不能随意删除。外码的设置在上面数据 库建表时已经提到。( 3) 主码约束保证实体的完整性, 主码的设置在上面数据表的设计时已提到
17、了。( 4)创建规则保证学生的年龄在18 岁到 35 岁之间(出生日期在1997-1-1 到1980-12-31 日之间) ,不会输入错误数据。( 4) 建触发器,保证在添加学生信息的时候,自动将该班级的必修课添加到选课表中。(以上只是该教务系统中实现数据完整性的部分方法。 实际上要考虑的还有很多方面,实现手法也是多种多样。在此留给学生自己思考。 )五、创建数据库代码USE masterCREATE DATABASE studyON PRIMARY(SQLServerMSSQLdatastudy.mdf,SQLServerMSSQLdatastudy.ldf,NAME=study_data,
18、FILENAME=C:Program FilesMicrosoft SIZE=10MB, MAXSIZE=UNLIMITED, FILEGROWTH=1MB )LOG ON(NAME=study_log, FILENAME=C:Program FilesMicrosoft SIZE=2MB, MAXSIZE=UNLIMITED, FILEGROWTH=1MB )USE studyCREATE TABLE class (classname char(9) primary key, maxcreadit smallint, mincreadit smallint)CREATE TABLE stud
19、ent(studentid char(10) primary key,name char(10), sex char(2), birthday datetime, classname char(9), Foreign Key(classname) References class(classname) )CREATE TABLE course(courseid char(6) primary key,coursename char(20), credit smallint, teacher char(10), acception smallint )CREATE TABLE classcour
20、se(classname char(9),courseid char(6),Primary Key(classname, courseid),Foreign Key(classname) References clase(classname), Foreign Key(courseid) References course(courseid) )CREATE TABLE studentcourse(studentid char(10),courseid char(6), grade smallint, Primary Key(studentid,courseid), Foreign Key(s
21、tudentid) References student(studentid), Foreign Key(courseid) References course(courseid) )CREATE TABLE coursetime(courseid char(6), coursetime smallint, Primary Key(courseid, coursetime), Foreign Key(courseid) References course(coueseid)CREATE TABLE user(uesrid char(10),userpasswd char(10),useraut
22、h smallint, studentid char(10)-USE studyinsert into class values(121131001,50,40)insert into class values(121131002,50,40)insert into class values(131131002,50,40)李平 , 男,1995-08-05,121131001)刘晓东 , 男,1996-01-15,121131001)王静 , 女,1996-02-10,121131002)李月 , 女,1996-5-25,131131002)insert into student value
23、s(1211310001, insert into student values(1211310002, insert into studentvalues(1211310048, insert into studentvalues(1311310048,insert into course values(000001, insert into course values(000002, insert into course values(000003, insert into course values(000004, insert into course values(000005,计算机
24、基础,3, 李建国 ,40)大学英语 ,5, 孙晓丽 ,30)数值分析,3, 吴东 ,30)政治经济学 ,3, 张欣 ,50)离散数学,3, 刘明,30)insert into classcourse values(121131001, 000001) insert into classcourse values(121131002, 000001) insert into classcourse values(131131002, 000001) insert into classcourse values(121131001, 000002) insert into classcourse
25、 values(121131002, 000002) insert into classcourse values(131131002, 000002) insert into classcourse values(121131001, 000003) insert into classcourse values(121131002, 000003) insert into classcourse values(121131001, 000004) insert into classcourse values(121131002, 000004)insert into classcourse
26、values(131131002, 000004) insert into classcourse values(121131001, 000005) insert into classcourse values(121131002, 000005)insert into studentcourse values(1211310001, 000001,85) insert into studentcourse values(1211310001, 000002,72) insert into studentcourse values(1211310001, 000003,null) inser
27、t into studentcourse values(1211310001, 000004,null) insert into studentcourse values(1211310001, 000005,null) insert into studentcourse values(1211310002, 000001,80) insert into studentcourse values(1211310002, 000002,78) insert into studentcourse values(1211310002, 000003,null) insert into student
28、course values(1211310002, 000004,null) insert into studentcourse values(1211310002, 000005,null) insert into studentcourse values(1211310048, 000001,88) insert into studentcourse values(1211310048, 000002,85) insert into studentcourse values(1211310048, 000003,null) insert into studentcourse values(
29、1211310048, 000004,null) insert into studentcourse values(1211310048, 000005,null) insert into studentcourse values(1311310048, 000001,null) insert into studentcourse values(1311310048, 000002,80) insert into studentcourse values(1311310048, 000004,null)insert into coursetime values(000001,13)insert
30、 into coursetime values(000002,21)insert into coursetime values(000003,31)insert into coursetime values(000004,32)insert into coursetime values(000005,42) insert into user values (admin,adminpw,0,null)insert into user values (st1,st1pw,1,1211310001)insert into user values (st2,st2pw,1,1211310002) insert into user values (st3,st3pw,1,1211310048)insert into user values (st4,st4pw,1,1311310048)六、总结1、小组分工情况:2、总结:通过做这次课程设计,(结合系统设计说明收获、体会)