数据库学生学籍管理系统.docx
一、系统定义二、需求分析1、系统综合需求2、系统逻辑模型三、系统设计1、概念结构设计2、逻辑结构设计3、系统功能设计四、详细设计1、开发平台及工具2、数据库的创建和链接3、编码设计4、界面设计五、课程设计总结六、参考文献七、评分表一、系统定义在学籍管理中,需要从大量的日常教学活动中提取相关信息,以反映教学情况。传统 的手工操作方式,易发生数据丢失,统计错误,劳动强度高,且速度慢。使用计算机可以 高速,快捷地完成以上工作。在计算机联网后,数据在网上传递,可以实现数据共享,避 免重复劳动,规范教学管理行为,从而提高了管理效率和水平,此外,现今学籍管理的繁 索给具有强烈时间观念的行政人员带来了诸多不便,教学办公室缺少一种完善的学籍管理 软件,为了对学生档案,学生信息的管理方便,因此开发了本软件。二、需求分析1、系统综合需求1. 系统需求分析需求分析是数据库系统设计的一个重要的环节。本阶段应该对整个应用情况作全面的、 详细的调查,确定特定数据库应用环境下的设计目标,收集该应用环境下针对系统设计所 需要的基础数据以及对这些数据的具体存储要求,从而确定用户的需求。用户对数据库的 需求包括:处理需求1、实现学生基本情况的录入,修改,删除等基本操作。2、对学生基本信息提供灵活的查询方式。3、完成一个班级的学期选课功能。4、实现学生成绩的录入,修改,删除等基本操作。5、能方便的对学生的个人学期成绩进行查询。6、具有成绩统计,排名等功能。7、具有留级,休学等特殊情况的处理功能。8、能输出常用的各种报表。9、具有数据备份和数据恢复功能。信息需求需要存储学生基本信息、课程、专业信息、课程设置信息、学生选课信息、管理人员的密 码信息。安全性和完整性功能设置身份密码验证登陆,进行数据维护,数据备份。2、系统逻辑模型1.数据流图:第一层学生名单学生信息合格单1.2是否新生 学生信息新生信息第四层统计成绩学生记录主要涉及到以下几个表,分别为:学生基本信息表,课程表,专业信息表,课程设置表,学生选课表,学生与专业之间的属于表以及管理人员的密码表。以下是数据字典:专业Sno学生的学号Sname_ 学生姓名_Ssex_性别_Ssbirth学生的出生年月学生基本信息表课程表Pno_专业编号_Pname_专业名称Pnum_专业人数_Pdept专业所在院系信息表课程设置表学学生与专Cno课程号Cname课程名Cperiod学时表Cno课程号Cname课程名Cperiod学时Sno学生的学号psenior学期cno课程编号grade成绩码表sno学生的学号pn管理人尸白W户专业的编号员的编号upasw管理人员的密码生选课表业的属于理人员密三、系统设计1、概念结构设计局部ER图学号专业号专业名人数属于专业ER图转换为2、逻A姓名院系模型性别出生年月学生课程号密码中有三个实体:学生,课程,和专业;三个关系:由ER图可见:乙间的属于关系,专业的课程设置。专业基本信息表:信息表:专业号关系的学号选课S (sno, sname, ssex, sbirth, spa成绩C (cno, cname, cperior学期学生选课关系,每个实体必须构造表,所以可以先得到三个实体的信息表,的属性即美写设置勺属性:学生基本信息、表:P (pno, pndme课程um, psdept)生日期,登陆密码对应的属性分别为:学号,时专业编号,专业名,专业人数,所在院系,性别对于多对多的关系来说,与该联系相连的实体的码以及本身的属性均转换为关系的属 性,各实体之间的码组成关系的码或者关系的码的一部分。以上ER图的三个联系为多对 多,所以转换为关系模式为:课程设置表:pc ( pno, psenior, cno)与设置相连的实体有专业和课程,根据多对多的转 换原则:专业的码pno,课程的码cno以及设置本身的属性共同构成该关系模式的码,所以 该关系模式的码为全码。学生选课表:SC (sno, psenior, cno, grade)与选课相连的实体有学生和课程,同上由学生 的码sno,课程的码cno以及选课本身的码psenior构成该关系模式的码,即(sno,cno,psenior)。 此外,选课表还有一个非主属性grade。学生与专业的属于表:SP(sno,pno)与属于关系相联的实体是学生和专业。同上由学生 的码sno,专业的码pno构成该关系模式的码,由于此关系没有其他的码也就没有非主属性。关系模式的优化:学生表 s (sno,sname,ssex,sbirth,spasw)该关系模式的码为sno,由于只有一个码,所以不存在非主属性对码的部分函数依赖, 可以达到2NCF。另外,该关系模式的函数依赖为:sno -> sname, sno -> ssex, sno -> ssex,sno -> sbirth, sno -> spasw,其间不存在传递依赖,故学生表可达到3NCF.课程表C ( cno ,cname , cperiod)该关系模式的码为cno, cname,设主码为cno,因为该关系模式中的码都是单一的,即 不存在有两个或者两个以上的属性组成的码,所以不存在非主属性对码的部分函数依赖, 可以达到2NCF。另外,该关系模式的函数依赖为:cno->cname, cno->cperiod, cname ->cno ,cname -> cperiod. 因为 cno -> cname,cname -> cperiod cno -> cperiod, 所以该 关系模式中存在传递依赖,不能达到3NCF。故优化该表为:C1(cno,period),C2(cname,cperiod).从而两表都达到了 3NCF。专业表 P (pno,pname,pnum,pdept)该关系模式的码为pno,pname,其中设定pno为主码。同课程表,该表不存在有两个或 者两个以上属性组成的码,即不存在非主属性对码的部分函数依赖,故可达到2NCF。另外, 此关系模式的函数依赖为:pno->pname, pno-> pnum, pno -> pdept , pname -> pno, pname->pnum, pname -> pdept; 由于存在传递依赖:pno -> pname, pname->pnum, pno -> pnum.,所以未能达到 3NCF。优化分解为:P1 (pno,pnum,pdept), P2 (pname,pnum,pdept)明显,两表都达到了 3NCF.课程设置表 PC(pno,psenior,cno),该关系模式的码为:(pno,psenior,cno)为全码,所以可直接达到3NCF学生选课表 SC(sno,psenior,cno,grade)该关系模式的码为:(sno,psenior,cno),因为不存在非主性grade对码的部分函数依赖, 所以可达到2NCF,由于不存在函数依赖(表中的函数依赖只有(sno,psenior,cno)-> grade) 故也达到了 3NCF属于表 SP(sno,pno)该关系模式的码(sno,pno)也是全码,所以也达到了 3NCF用户表 U(uname,upasw)该表的码为uname,明显upasw对码uname是完全函数依赖的,从而达到2NCF。另外 因为只有两个属性,所以不存在传递函数依赖,该表达到了 3NCF3、系统功能设计四、详细设计1、开发平台及工具 开发工具Microsoft Visual C+ 6.0 DBMS:Microsoft SQL Server 2000 建模工具: Microsoft Visio, Sybase PowerDesigner2、数据库的创建和链接本系统的前台开发工具为Microsoft visual basic 6.0 ,除了一些常用的控件ADOCommandbutton,Combobox,Textbox 和 Label 夕卜,这里还使用 了控件 ADO 和 DataGrid。 用来链接数据库与前台开发程序,指定链接的数据源和要访问的数据,并通过绑定要使用 的数据来显示所获得的数据°DataGrid控件的作用是以表格的形式显示结果中的全部数据, 但允许在表格中增加,删除和修改纪录。具体的链接过程如下:ADO (步骤)(1)选择“工程”菜单中的部件命令,打开部件对话框,在控件选项中选择Microsoft ADO Data Control 6.0(OLEDB)复选框,单击确定,工具栏中会出现ADO数据控件的图标, 其微帮助名称为:Adodc。(2)在当前窗体上添加一个ADO控件。(3)打开ADO的属性页,设置使用的ODBC数据资源的名称,(如果没有则新建一 个)即我所使用的数据库wangjiaDSN;设置身份验证,包括用户名称和密码;设置纪录源, 命令类型选择adCmdTable.(因为我所用到的记录源都是表,所以设置为该属性°adCmdTable. 表示的是数据源的属性是一个表名,表示其结果级是对该表执行无条件查询后得到的结 果),表名或存储过程名则选择自己所要用到的表。到此,便链接成功。DataGrid (步骤)(1)同ADO控件一样,选择选择“工程”菜单中的部件命令,打开部件对话框,在 控件选项中选择Microsoft DataGrid Control 6.0(OLEDB)复选框,单击确定,工具栏中会 出现DataGrid数据控件的图标。(2)在当前窗体上添加一个DataGrid控件。(3)打开DataGrid的属性页,设置标题名,列,列标题与其对应的数据段。颜色, 字体等可根据需要设定。将DataGrid的Recordsource设置为该窗体对应的Adodc;另外可检 索字段和删除字段,这样可以显示自己想要的字段,而不是将adodc所对应的内容全部显 示出来。到此,链接成功。3、编码设计1用SQL语言完成以下功能:(1 )每个表建表的主外码 系信息表代码如下:use XJGLgocreate table DEPT(deptid char ( 10 ) not null,deptname nvarchar (10 ) primary key ,);班级信息表代码如下: use XJGL gocreate table CLASS(classid char ( 8 ) primary key,proname nvarchar ( 20 ) not null,deptname nvarchar ( 10 ) not null,smalldatetime not null );学生信息表代码如下:create table STUDENT(sno char ( 5 ) primary keysname nvarchar ( 10 n)ot null,sage int not null,classid char ( 8 ) not null, );各表外码声明如下:use XJGL goalter tablSTUDENTadd foreign key ( classid ) references CLASS ( classid )alter tablCeLASSadd foreign key ( deptname ) references DEPT ( deptname )(2每个班级的人数不能超过30人。alter table CLASS add studentnum smallintcreate rule studentnum_rule as studentnum > = 0 and studentnum < = 30 (3学生的年龄介于15到40岁之间。alter table STUDENTadd check ( sage between 15 and 40 )(4 )只有班里没有学生的时候,才能删除该班级。deletefrom CLASSwhere studentnum = 04、界面设计登陆界面主界面添加用户界面学生密码修改界面个人信息维护界面成绩统计信息查询成绩查询五、课程设计总结经过近一个星期的努力,终于设计出一个达到程序设计要求的数据库。其功?能完整, 用户界面良好,但是也存在着某些缺陷。?这一段时间的工作努力,最后的结果固重要,但更重要的是它让自己了解了?数据 库设计的一般过程。在接受客户的一个项目的时候,首先是进行系统分析。?既首先分析其 以后的销售情况以及技术可行性。如果二者可行,我们接下来做的?就是总体设计。我们首 先必须听取用户的要求,将其提出的功能按某种方式划分?为几种模块。这就是整体设计。 在对每一个模块进行细化形成最为简单的模块。?然后是考虑每一细化模块的算法并将其用 语言刻画出来。这就是详细设计。这就?迈出了最为关键的一步。剩下的就是编译测试阶段。 这是编程的必经阶段,也是?我们劳动结果的验金石。只有得到我们期望的结果我们才算真 正完成了任务。最?后是软件的维护。在软件的使用过程中不可避免地会出现一些错误,因 此维护便?是必不可少的。这便是完成一个项目必经的过程。??克服困难,坚持不懈是一个成功人士的所必需的品质。同样作为一个软件编?程者更 是必不可少的。只有敢于对困难说不,我们才能成为真正的软件编程者。?不懈上帝是公平 的,又付出就有回报。眼前的困难只是你前进路上的绊脚石。只?要我们不怕痛,我们就能 坚持的走下来,最终走向胜利。六、参考文献1. Visual C+ .net 2003程序设计何炜等 冶金工业出版社P247-2612. 数据库系统原理教程王珊等清华大学出版社3. Windows用户界面开发美Everett N. McKay着 北京大学出版社4. Visual Basic应用与开发案例教程清华大学出版社出版徐立吴明旺编着七、评分表课程设计评分表课程名称: 数据库原理项目评价设计方案的合理性与创造性设计与调试结果设计说明书的质量答辩陈述与回答问题情况课程设计周表现情况综合成绩教师签名:日 期: