数据库课程设计学生成绩管理系统

上传人:痛*** 文档编号:83392001 上传时间:2022-05-01 格式:DOC 页数:30 大小:363.50KB
收藏 版权申诉 举报 下载
数据库课程设计学生成绩管理系统_第1页
第1页 / 共30页
数据库课程设计学生成绩管理系统_第2页
第2页 / 共30页
数据库课程设计学生成绩管理系统_第3页
第3页 / 共30页
资源描述:

《数据库课程设计学生成绩管理系统》由会员分享,可在线阅读,更多相关《数据库课程设计学生成绩管理系统(30页珍藏版)》请在装配图网上搜索。

1、得分:课程设计报告学生信息管理系统设计姓名 李富荣班级09网络1班学号20090504113课程名称数据库原理及应用指导教师王建颖2012年1月3日 目录一 概述.11.1目的与要求.11.2设计环境.1二 需求分析.12.1 系统功能要求设计.12.2 系统模块设计12.3 数据字典2三 概念模型设计.4四 逻辑和物理结构设计.44.1由系统ER图转化而得到的关系模式54.2 确定关系模型的存取方法.54.3 确定数据库的存储结构.55.1 数据库的实施5五 数据库的实施与维护.55.1 数据库的实施65.2部分操作截图255.3数据库的维护.27六 总结27 学生信息管理系统一 概述1.1

2、目的与要求随着科技的发展,基本上所有的具有一定数量数据的机构都开始使用计算机数据库来做管理。几乎所有学校也都已经在使用计算机管理数据的机制,大大减少了学校学生成绩管理的工作量。该课程设计要求设计一个学生成绩的数据库管理系统,数据库中要求包含学生的基本信息,学科基本信息,以及学生所学课程的考试成绩。要方便学生进行成绩查询,通过该课程设计,应该达到把数据库理论知识更加的巩固加深,加强动手能力与实践能力,学以致用,与现实生活中的应用充分的结合起来。1.2设计环境Microsoft SQL Server 2000Microsoft Visual C+ 6.0二 需求分析2.1 系统功能要求设计此系统实

3、现如下系统功能:(1)使得学生的成绩管理工作更加清晰、条理化、自动化。(2)通过用登录系统,查询学生基本信息,学生所选课程成绩,添加或删除等功能。 容易地完成学生信息的查询操作。(3) 设计人机友好界面,功能安排合理,操作使用方便,并且进一步考虑系统在安全性,完整性,并发控制,备份和恢复等方面的功能要求。2.2 系统模块设计成绩管理系统大体可以分成二大模块如, 一是学生的基本信息模块,里面应该包含学生的各方面的基本信息;再者便是课程管理模块, 在该模块中应该包含有对学生成绩信息的查询和处理,如平均成绩、最好成绩、最差成绩以及不及格学生的统计等功能模块;再其次还有教师、课程等相关信息的模块;可以

4、得到系统流程图:登陆失败班级信息学生信息退出系统用户验证教师信息登陆成功学生成绩查询选课信息课程信息2.3 数据字典 数据项是数据库的关系中不可再分的数据单位,下表分别列出了数据的名称、数据类型、长度、取值能否为空。利用SQL Server 2000建立“学生选课”数据库,其基本表清单及表结构描述如下:数据库中用到的表:数据库表名关系模式名称备注Student学生学生个人信息表Course课程课程基本信息表Class班级班级成绩信息表SC学生选课学生选课信息SC基本情况数据表,结构如下:字段名字段类型Not Null说明SC _snoCharPrimary key学号Student _Cnoc

5、harPrimary key课程号Student _Gradeintnot null成绩Student表信息Student _SnocharPrimary key学号Student _Snamevarcharnot null姓名Student _Ssexcharnot null性别Student _Sageintnot null年龄Student _SClnocharnot null班级号course数据表,结构如下:字段名字段类型约束控制说明C ourse_cnochar主键(primary key)课程号C ourse_cnamevarcharreference 课程名C ourse_cp

6、nocharnot null先修课课号C ourse_ccreditintnot null学分Course ctnocharnot null教师号Class情况数据表,结构如下:字段名字段类型约束控制说明C lass clnocharprimary key班级号C lass clnamevarcharnot null班级名称三 概念模型设计由需求分析的结果可知,本系统设计的实体包括:(1)学生基本信息:(学号,姓名,性别,年龄,班级号,成绩)。(2)课程基本信息:( 课程名,课程号,先修课课号,教师号,学分)。 这些实体间的联系包括:(1)每位学生可以学习多门课程,每门课程可供多位学生学习。由

7、上述分析可得到系统的ER图:班级课程号先修棵名称 课程名名成绩课程教师号学号学生姓名学分性别班级号班级号班级成绩年龄四 逻辑和物理结构设计4.1由系统ER图转化而得到的关系模式如下:(1)学生(学号,姓名,性别,年龄,班级号)(2)课程(课程号,课程名,先修课程号,学分,教师号),其中主关键字为课程号;(3)班级(班级号,班级成绩)其中主关键字为班级号。可以与学生关系模式合并为:学生(课程号号,成绩,班级号,班级成绩)。4.2 确定关系模型的存取方法在将概念模型转换成物理模型之后,我们可以对物理模型进行设计,双击物理模型的关系,可以对该关系的名称、注释等信息进行查询。可对该关系的属性列进行设计

8、,可分别设置其名称、码、数据类型以及主码、是否为空等。在实际设计中最常用的存取方法是索引发,使用索引可以大大减少数据的查询时间,在建立索引时应遵循:在经常需要搜索的列上建立索引; 在主关键字上建立索引;在经常用于连接的列上建立索引,即在外键上建立索引;在经常需要根据范围进行搜索的列上创建索引,因为索引已经排序,其指定的范围是连续的等规则。才能充分利用索引的作用避免因索引引起的负面作用。4.3 确定数据库的存储结构确定数据库的存储结构主要指确定数据的存放位置和存储结构,包括确定关系、索引、日志、备份等的存储安排及存储结构,以及确定系统存储参数的配置。因为该成绩管理系统的数据量小,所以我们只用把数

9、据存储在使用的电脑硬盘上,不用作更多的安排。(1) 创建学生基本信息表:下图显示了学生,课程和成绩三个关系的物理设计其中课程号与学号号分别为关系的主码。 五 数据库的实施与维护5.1 数据库的实施:此阶段主要任务包括创建数据库,加载初始数据,数据库试运行,数据库的安全性和完整性控制数据库的备份与恢复,数据库性能的监督分析和改仅,数据库的重组和重构等。首先在数据库中建立一个学生成绩管理系统数据库,然后新建一个数据源。主要代码如下:void CDialogSTU:Add()_variant_t var;CString str;UpdateData(true);if(m_StuID.IsEmpty(

10、) |atof(m_StuID)=0)AfxMessageBox(请重新输入正确的学生学号);return;if(m_ClaID.IsEmpty() |atof(m_ClaID)=0)AfxMessageBox(请重新输入正确的班级号);return;if(!m_pRecordsetCLA-adoBOF)m_pRecordsetCLA-MoveFirst();while(!m_pRecordsetCLA-adoEOF) /比较将要加入的班级号,查看该班级号是否在班级表中存在var=m_pRecordsetCLA-GetCollect(Clno);str=(LPCSTR)_bstr_t(var)

11、;if(atof(m_ClaID)=atof(str)break;m_pRecordsetCLA-MoveNext();if(m_pRecordsetCLA-adoEOF)AfxMessageBox(请重新输入正确的班级号!);return;if(!m_pRecordset-adoBOF)m_pRecordset-MoveFirst();while(!m_pRecordset-adoEOF) /比较讲要加入的学生学号,查看该学生是否已经存在var=m_pRecordset-GetCollect(Sno);str=(LPCSTR)_bstr_t(var);if(atof(m_StuID)=ato

12、f(str)AfxMessageBox(该学生已存在);break;m_pRecordset-MoveNext();if(!m_pRecordset-adoEOF)return;elsetrym_pRecordset-AddNew(); m_pRecordset-PutCollect(Sno,_variant_t(m_StuID); m_pRecordset-PutCollect(Sname,_variant_t(m_StuName); var.iVal=m_StuAge; m_pRecordset-PutCollect(Sage,var.iVal); m_pRecordset-PutColl

13、ect(Ssex,_variant_t(m_StuSex); m_pRecordset-PutCollect(Sclno,_variant_t(m_ClaID); m_pRecordset-Update(); m_pRecordset-MoveFirst();m_grid.DeleteAllItems(); AddToGrid();m_pRecordset-MoveLast(); AfxMessageBox(插入成功!); catch(_com_error *e) AfxMessageBox(e-ErrorMessage();void CDialogSTU:Modify()_variant_t

14、 var;CString str;UpdateData(true);if(m_StuID= | atof(m_StuID)=0)AfxMessageBox(学号不能为空);return;if(m_ClaID.IsEmpty() |atof(m_ClaID)=0)AfxMessageBox(请重新输入正确的班级号);return;if(!m_pRecordsetCLA-adoBOF)m_pRecordsetCLA-MoveFirst();while(!m_pRecordsetCLA-adoEOF) /比较将要加入的班级号,查看该班级号是否在班级表中存在var=m_pRecordsetCLA-Ge

15、tCollect(Clno);str=(LPCSTR)_bstr_t(var);if(atof(m_ClaID)=atof(str)break;m_pRecordsetCLA-MoveNext();if(m_pRecordsetCLA-adoEOF)AfxMessageBox(请输入正确的班级号);return;elsetry m_pRecordset-PutCollect(Sno,_variant_t(m_StuID); m_pRecordset-PutCollect(Sname,_variant_t(m_StuName); var.iVal=m_StuAge; m_pRecordset-P

16、utCollect(Sage,var.iVal); m_pRecordset-PutCollect(Ssex,_variant_t(m_StuSex) m_pRecordset-PutCollect(Sclno,_variant_t(m_ClaID); m_pRecordset-Update(); m_pRecordset-MoveFirst();m_grid.DeleteAllItems(); AddToGrid();m_pRecordset-MoveLast(); AfxMessageBox(修改成功!); catch(_com_error *e) AfxMessageBox(e-Erro

17、rMessage();void CDialogSTU:OnButtonNext() / TODO: Add your control notification handler code herem_pRecordset-MoveNext();_variant_t var;CString str;if(m_pRecordset-adoEOF)MessageBox(已经是末记录!);m_pRecordset-MoveLast();tryvar=m_pRecordset-GetCollect(Sno);str=(LPCSTR)_bstr_t(var);m_StuID=str;var=m_pRecor

18、dset-GetCollect(Sname);str=(LPCSTR)_bstr_t(var);m_StuName=str;var =m_pRecordset-GetCollect(Sage);m_StuAge=var.iVal; var=m_pRecordset-GetCollect(Ssex); str=(LPCSTR)_bstr_t(var);m_StuSex=str;var=m_pRecordset-GetCollect(Sclno);str=(LPCSTR)_bstr_t(var);m_ClaID=str;UpdateData(false);catch(_com_error *e)A

19、fxMessageBox(e-ErrorMessage();BOOL CDialogCOU:OnInitDialog() CDialog:OnInitDialog();/ TODO: Add extra initialization herem_grid.SetExtendedStyle(LVS_EX_FLATSB|LVS_EX_FULLROWSELECT|LVS_EX_HEADERDRAGDROP|LVS_EX_ONECLICKACTIVATE|LVS_EX_GRIDLINES);m_grid.InsertColumn(0,课程号,LVCFMT_LEFT,100,0);m_grid.Inse

20、rtColumn(1,课程名,LVCFMT_LEFT,100,0);m_grid.InsertColumn(2,先修课课号,LVCFMT_LEFT,100,0);m_grid.InsertColumn(3,学分,LVCFMT_LEFT,100,0);m_grid.InsertColumn(4,教师号,LVCFMT_LEFT,100,0);m_pRecordset.CreateInstance(_uuidof(Recordset);m_pRecordsetCOU.CreateInstance(_uuidof(Recordset);m_pRecordsetSC.CreateInstance(_uu

21、idof(Recordset);m_pRecordsetTno.CreateInstance(_uuidof(Recordset);m_pRecordsetCno.CreateInstance(_uuidof(Recordset);/打开Student表OpenCOURSES();catch(_com_error *e)AfxMessageBox(e-ErrorMessage();return TRUE; / return TRUE unless you set the focus to a control / EXCEPTION: OCX Property Pages should retu

22、rn FALSEvoid CDialogCOU:Add()_variant_t var;CString str;UpdateData(true);if(m_CouID=|atof(m_CouID)=0)AfxMessageBox(请重新输入正确的课程号);return;if(m_TID=|atof(m_TID)=0)AfxMessageBox(请重新输入正确的教师号);return;if(m_TID=|atof(m_TID)=0)AfxMessageBox(请重新输入正确的先修课课程号);return;void CDialogCOU:Modify() /存在1个问题,当先修课为11,12时会有

23、异常_variant_t var;CString str,strb;UpdateData(true);if(m_CouID= | atof(m_CouID)=0)AfxMessageBox(课程号不能为空);return;if(m_TID= | atof(m_TID)=0)AfxMessageBox(教师号不能为空);return;if(/*m_CouPno= | */atof(m_CouPno)=0)AfxMessageBox(先修课课程号不能为0);return;if(!m_pRecordsetTno-adoBOF)m_pRecordsetTno-MoveFirst();while(!m_

24、pRecordsetTno-adoEOF) var=m_pRecordsetTno-GetCollect(Tno);str=(LPCSTR)_bstr_t(var);if(atof(m_TID)=atof(str)break;m_pRecordsetTno-MoveNext();if(m_pRecordsetTno-adoEOF)AfxMessageBox(请输入正确的教师号);return;if(!m_pRecordsetCno-adoBOF)m_pRecordsetCno-MoveFirst(); while(!m_pRecordsetCno-adoEOF) var=m_pRecordse

25、tCno-GetCollect(Cno); strb=(LPCSTR)_bstr_t(var); if(atof(m_CouPno)=atof(strb)break; m_pRecordsetCno-MoveNext(); if(m_pRecordsetCno-adoEOF) AfxMessageBox(请输入正确的先修课课程号); return; else try m_pRecordset-PutCollect(Cno,_variant_t(m_CouID); m_pRecordset-PutCollect(Cname,_variant_t(m_CouName); m_pRecordset-

26、PutCollect(Cpno,_variant_t(m_CouPno); var.iVal=m_CouCredit; m_pRecordset-PutCollect(Ccredit,var.iVal); m_pRecordset-PutCollect(CTno,_variant_t(m_TID); m_pRecordset-Update(); m_pRecordset-MoveFirst(); m_grid.DeleteAllItems(); AddToGrid(); m_pRecordset-MoveLast(); AfxMessageBox(修改成功!); catch(_com_erro

27、r *e) AfxMessageBox(e-ErrorMessage(); void CDialogCLA:Add()_variant_t var;CString str;UpdateData(true);if(m_ClaID=|atof(m_ClaID)=0)AfxMessageBox(请重新输入正确的课程号);return;if(atof(m_ClaID)!=0 &(!m_pRecordset-adoBOF)m_pRecordset-MoveFirst();while(!m_pRecordset-adoEOF) /比较讲要加入的学生学号,查看该学生是否已经存在var=m_pRecordse

28、t-GetCollect(Clno);str=(LPCSTR)_bstr_t(var);if(atof(m_ClaID)=atof(str)AfxMessageBox(该班级已存在);break;m_pRecordset-MoveNext();if(!m_pRecordset-adoEOF)return;elsetrym_pRecordset-AddNew(); m_pRecordset-PutCollect(Clno,_variant_t(m_ClaID); m_pRecordset-PutCollect(Clname,_variant_t(m_ClaName); m_pRecordset-

29、Update(); m_pRecordset-MoveFirst();m_grid.DeleteAllItems(); AddToGrid();m_pRecordset-MoveLast(); AfxMessageBox(插入成功!); catch(_com_error *e) AfxMessageBox(e-ErrorMessage();void CDialogCLA:Delete()_variant_t var;CString str,stra,strb;UpdateData(true);if(m_ClaID= | atof(m_ClaID)=0)MessageBox(请输入要删除的班级号

30、!);return;if(atof(m_ClaID)!=0 &(!m_pRecordset-adoBOF)m_pRecordset-MoveFirst();while(!m_pRecordset-adoEOF) /比较讲要加入的学生学号,查看该学生是否已经存在var=m_pRecordset-GetCollect(Clno);str=(LPCSTR)_bstr_t(var);if(atof(m_ClaID)=atof(str)strb.Format(SELECT * FROM Student where SClno=%s,m_ClaID);try /从SQL数据库中打开Student表 m_p

31、RecordsetSTU-Open(strb.AllocSysString(), theApp.m_pConnection.GetInterfacePtr(), adOpenDynamic, adLockOptimistic, adCmdText);if(!m_pRecordsetSTU-adoEOF) AfxMessageBox(此数据正在被表外数据使用,不能删除!); m_pRecordsetSTU-Close(); return; catch(_com_error *e) AfxMessageBox(e-ErrorMessage();m_pRecordsetSTU-Close();m_p

32、Recordset-Delete(adAffectCurrent); m_pRecordset-Update(); m_pRecordset-MoveFirst();m_grid.DeleteAllItems(); AddToGrid();m_pRecordset-MoveLast();if(m_pRecordset-adoBOF)AfxMessageBox(表内数据已经为空); m_btnAdd.SetState(true); m_btnQuery.EnableWindow(FALSE); m_btnDelete.EnableWindow(FALSE); m_btnModify.Enable

33、Window(FALSE); m_btnFirst.EnableWindow(FALSE); m_btnPre.EnableWindow(FALSE); m_btnNext.EnableWindow(FALSE); m_btnLast.EnableWindow(FALSE); m_btnOK.SetFocus();break;m_pRecordset-MoveNext();if(m_pRecordset-adoEOF) AfxMessageBox(不存在该班级号,请重新输入正确的学号);void CDialogCLA:Modify()_variant_t var;UpdateData(true

34、);if(m_ClaID= | atof(m_ClaID)=0)AfxMessageBox(学号不能为空);return;try m_pRecordset-PutCollect(Clno,_variant_t(m_ClaID); m_pRecordset-PutCollect(Clname,_variant_t(m_ClaName); m_pRecordset-Update(); m_pRecordset-MoveFirst();m_grid.DeleteAllItems(); AddToGrid();m_pRecordset-MoveLast(); AfxMessageBox(修改成功!);

35、 catch(_com_error *e) AfxMessageBox(e-ErrorMessage();void CDialogCLA:OnButtonFirst() / TODO: Add your control notification handler code herem_pRecordset-MoveFirst();_variant_t var;CString str;tryvar=m_pRecordset-GetCollect(Clno);str=(LPCSTR)_bstr_t(var);m_ClaID=str;var=m_pRecordset-GetCollect(Clname

36、);str=(LPCSTR)_bstr_t(var);m_ClaName=str;UpdateData(false);catch(_com_error *e)AfxMessageBox(e-ErrorMessage();void CDialogCLA:OnButtonPre() / TODO: Add your control notification handler code herem_pRecordset-MovePrevious();_variant_t var;CString str;if(m_pRecordset-adoBOF)MessageBox(已经是第一条记录!);m_pRe

37、cordset-MoveFirst();tryvar=m_pRecordset-GetCollect(Clno);str=(LPCSTR)_bstr_t(var);m_ClaID=str;var=m_pRecordset-GetCollect(Clname);str=(LPCSTR)_bstr_t(var);m_ClaName=str;UpdateData(false);catch(_com_error *e)AfxMessageBox(e-ErrorMessage();void CDialogCLA:OnButtonNext() / TODO: Add your control notifi

38、cation handler code herem_pRecordset-MoveNext();_variant_t var;CString str;if(m_pRecordset-adoEOF)MessageBox(已经是末记录!);m_pRecordset-MoveLast();tryvar=m_pRecordset-GetCollect(Clno);str=(LPCSTR)_bstr_t(var);m_ClaID=str;var=m_pRecordset-GetCollect(Clname);str=(LPCSTR)_bstr_t(var);m_ClaName=str;UpdateDat

39、a(false);catch(_com_error *e)AfxMessageBox(e-ErrorMessage();void CDialogCLA:OnButtonLast() / TODO: Add your control notification handler code herem_pRecordset-MoveLast();_variant_t var;CString str;tryvar=m_pRecordset-GetCollect(Clno);str=(LPCSTR)_bstr_t(var);m_ClaID=str;var=m_pRecordset-GetCollect(C

40、lname);str=(LPCSTR)_bstr_t(var);m_ClaName=str;UpdateData(false);catch(_com_error *e)AfxMessageBox(e-ErrorMessage();第- 24 - -页5.2部分操作截图:第- 27 -页下图显示了学生登陆系统进行查询时界面:下图显示了进行班级查询时界面:查找班级号为9的班级名添加班级号为10,班级名为信电学院添加前添加成功添加后查找排列最前的班级查找最后的班级号查找学号为200215132学生的个人信息查找排在最后的学生信息5.3数据库的维护当试运行数据库合格后,数据库开发设计的工作就基本完成了

41、,接下来就是正式运行中的调试,应为该系统比较简单,数据量小,数据库中几乎不会发生什么大的变化,但是还是需要做好数据的备份,在sqlserver中我们可以利用备份数据库的功能对已经设计好的数据做备份,如果数据库受到破坏或系统故障,我们便可轻松的利用备份文件恢复数据库的数据。当然也可以利用其他各种方法进行数据维护。六 总结进一步深入理解数据库设计的整个过程,该学生选课系统的需求分析、数据库概念结构设计有关内容等。掌握使用前台程序设计技术VC和SQL Server结合设计C /S结构的管理信息系统。综合练习了SQL Server的使用和数据库得管理技术。综合熟悉并练习了SQL语言在编程中的使用。 综

42、合训练编程能力。认识系统,取得系统需求分析,更重要得是在编程方面提高了实现目标代码得能力及调试代码得能力参考文献(1)Visual C+数据库开发经典实例精解作者:夏邦国 刘凡馨 出版社:机械工业出版社(2)SQL SERVER 200管理,开发及应用实例作者:陈世洪 出版社:人民邮电出版社(3)Visual C+程序设计教程 作者:周鸣扬 于秋生 出版社:机械工业出版社 (4)数据库原理与应用 作者:姜代红 出版社:机械工业出版社(5) S.Sanyal and P.ChattopadhyayEffect of exponentially distributed deep levels on the current and capacitance of a MIS diodeJSolid-state electronics,2001,45(2):315-324

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

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!