软件工程课程实验报告系统名称___学生信息管理系统___学院___计算机学院信息___学生信息管理系统设计文档1.可行性研究1.1技术可行性已经有人开发过,并且我们也都使用过相类似系统,对其一般性的软件和操作环境、编译环境都比较熟悉,所以说在技术上来说是可行的。1.2经济可行性当前系统只对服务器有关的要求,在服务费用方面,支出在你那个承担的范围,以后的维护及其他设备的总共费用在可以承担的范围。用当前系统可以节约出能够支付当前系统的直接支出,以后维护费用更是比以前的机制节约很多钱。1.3操作可行性系统的操作方式在这个用户组织内能行得通。2.需求分析2.1输入让学生在纸面上填写相关内容,然后等待辅导员或管理员的审批确认后,再输入数据库中保存。2.2输出学生选择用户选项进入系统后,系统可经有算法程序输出学生基本信息表,学习成绩表等。2.2.1打印输出可打印基本信息、学习成绩等各种表格以及在对相应信息进行统计操作后的表格。2.2.2文件输出可将所有打印表格输出到EXCEL文件中,以便用户使用其它的EXCEL软件改变表格的大小及字体。2.3故障处理2.3.1内部故障处理在开发阶段可以随即修改数据库里的相应内容。2.3.2外部故障处理对编辑的程序进行重装载时,第一次装载认为错,修改。第二次运行,在需求调用时出错,有错误提示,重试。2.4性能要求分析2.4.1系统易操作性所开发的系统应做到操作简单,尽量使系统操作不受用户对电脑知识水平的限制。2.4.2系统具有可维护性由于系统涉及的信息比较广,数据库中的数据需定期修改,系统可利用的空间及性能也随之下降,为了使系统更好地运转,学院可以对系统数据及一些简单的功能进行独立的维护及调整。2.4.3系统具有开放性该系统能够在开放的硬件体系结构中运行,并且能与其他系统顺利连接,不会因外部系统的不同面要做在量的修改工作。3.概要设计3.1基本设计概念和处理流程管理员通过密码认证,进入信息管理页面对学生相关信息的录入、更新、修改、添加等操作,也可以通过查询界面对学生信息进行完全的查询,而学生和相关人员只能通过公共的查询界面对学生信息进行查询,如要对学生信息进行完全查询就需要得到管理员的同意。3.2接口设计本系统采用快速原型开发工具VisualBasic6.0进行开发,所提供的不同层次的接口,都具有高度的集成性,本系统没有采用低级语言设计和完成自定义接口,因此接口设计部分已经由不同方式的组件来完成了,以下只做简单说明。3.2.1用户接口说明将向用户提供的命令和它们的语法结构,以及软件的回答信息。命令语法信息正确信息错误提交IFELSE进入系统返回到当前界面重设点击事件清空输入的数据无取消点击事件返回到当前界面无3.2.2外部接口管理界面数据中心处理处理打印查询管理员操作信息输出查询用户界面说明本系统同外界的所有接口的安排包括软件与硬件之间的接口、本系统与各支持软件直接的关系。硬件接口软件接口键盘鼠标打印机主模块√√管理模块√√√查询模块√√√3.2.3内部接口说明本系统之内的各个系统元素之间的接口的安排。数据库接口设计采用ADO连接方式。模块名称主模块管理员验证模块用户查询界面管理界面主模块√√√管理员验证模块√√用户查询界面√管理界面√√4.详细设计4.1控制流程图4.1.1主模块软件结构登录模块用户选择学生管理员4.1.2管理员登陆软件结构登录模块管理员管理界面身份确认否选择操作IF正确否录入信息输出信息修改信息删除信息文件保存4.1.3用户查询软件结构用户查询模块输入查询条件IF正确输出结果ELSE打印出结果返回重新输入条件登录模块身份确认否用户查询模块输入查询条件IF正确输出结果ELSE打印出结果返回重新输入条件4.2源程序流程图运行主程序新建保存文件调用menuchoice输入select==1调用menu()Y清屏2:Add()5:Insert()调用menu()Ysaveflag==1保存输入操作选择select6:Tongji()9:System()4:Modify()8:Save()7:Sort()3:Qur()1:Del()wrong()N调用menustudent()清屏menustudent()输入selectselect==0saveflag==1保存输入select3:Qur()wrong()5、项目测试功能截图:5.1登陆界面5.2学生用户功能界面5.3学生查询功能5.4管理员管理界面5.5管理员输入功能5.6管理员删除功能5.7管理员查询功能5.8管理员修改功能5.9管理员插入功能5.10统计功能5.11分类功能5.12显示功能5.13管理员保存功能文件保存名为:STUDENT路径为:C:\6、项目管理6、1人员管理团队负责人:陶修赟小组成员:万富,洪鑫,汪贤惠,项鑫6、2产品管理本产品工作于Win-TC工作环境,用于对学生成绩的管理。学生用户,可进行查询课程成绩;管理员可对学生及其成绩进行录入、修改、查询、排列等功能。本系统可进行维护,修改。6、3进程管理可行性分析:5月23日-5月24日标志:提交可行性分析报告项目开发计划:5月25日-5月26日标志:提交项目开发计划需求分析:5月27日-5月27日标志:完成需求分析报告软件设计:5月30日-6月1日标志:完成软件分析与设计文档编程实现:6月2日-6月10日标志:代码编写全部完成软件测试:6月13日-6月14日标志:完成软件测试,可投入使用6、4项目计划甘特图7、编码#includestdio.h#includestdlib.h#includestring.h#includeconio.h#defineHEADER1----------------------------STUDENT----------------------------------\n#defineHEADER2|number|name|Comp|Math|Eng|sum|ave|mici|\n#defineHEADER3|---------------|---------------|----|----|----|--------|-------|-----|#defineFORMAT|%-10s|%-15s|%4d|%4d|%4d|%4d|%.2f|%4d|\n#defineDATAp-data.num,p-data.name,p-data.egrade,p-data.mgrade,p-data.cgrade,p-data.total,p-data.ave,p-data.mingci#defineEND---------------------------------------------------------------------\nintsaveflag=0;/*是否需要存盘的标志变量*/typedefstructstudent/*标记为student*/{charnum[10];/*学号*/charname[15];/*姓名*/intcgrade;/*C语言成绩*/intmgrade;/*数学成绩*/integrade;/*英语成绩*/inttotal;/*总分*/floatave;/*平均分*/intmingci;/*名次*/};typedefstructnode/*定义每条记录或结点的数据结构,标记为node*/{structstudentdata;structnode*next;}Node,*Link;voidmenuchoice(){system(cls);/*清屏.与clrscr()功能相同*/textcolor(10);/*在文本模式中选择新的字符颜色*/gotoxy(7,5);cprintf(TheStudents'GradeManagementSystem\n);gotoxy(7,8);printf(\nPleaseEnteryourchoice;0enterstudents'system\n\t\t\t);printf();printf(1enterteachers'system\n);}voidmenu()/*菜单函数*/{system(cls);/*清屏.与clrscr()功能相同*/textcolor(10);/*在文本模式中选择新的字符颜色*/gotoxy(7,5);/*在文本窗口中设置光标,下同*/cprintf(TheStudents'GradeManagementSystem\n);gotoxy(7,8);cprintf(*************************Menu********************************\n);gotoxy(7,9);cprintf(*1inputrecord2deleterecord*\n);gotoxy(7,10);cprintf(*3searchrecord4modifyrecord*\n);gotoxy(7,11);cprintf(*5insertrecord6countrecord*\n);gotoxy(7,12);cprintf(*7sortreord8saverecord*\n);gotoxy(7,13);cprintf(*9displayrecord0quitsystem*\n);gotoxy(7,14);cprintf(*************************************************************\n);/*cprintf()送格式化输出至文本窗口屏幕中*/}voidmenustudent(){system(cls);/*清屏.与clrscr()功能相同*/textcolor(10);/*在文本模式中选择新的字符颜色*/gotoxy(7,5);/*在文本窗口中设置光标,下同*/cprintf(TheStudents'GradeManagementSystem\n);gotoxy(7,8);cprintf(*************************Menu********************************\n);gotoxy(7,9);cprintf(*3searchrecord0quitsystem*\n);gotoxy(7,10);cprintf(*************************************************************\n);/*cprintf()送格式化输出至文本窗口屏幕中*/}voidprintheader()/*格式化输出表头*/{printf(HEADER1);printf(HEADER2);printf(HEADER3);}voidprintdata(Node*pp)/*格式化输出表中数据*/{Node*p;p=pp;printf(FORMAT,DATA);}voidWrong()/*输出按键错误信息*/{printf(\n\n\n\n\n***********Error:inputhaswrong!pressanykeytocontinue**********\n);getchar();}voidNofind()/*输出未查找此学生的信息*/{printf(\n=====Notfindthisstudent!\n);}voidDisp(Linkl)/*显示单链表l中存储的学生记录,内容为student结构中定义的数据项*/{Node*p;p=l-next;/*l存储的是单链表中头结点的指针,该头结点没有存储学生信息,指针域指向的后继结点才有学生信息*/if(!p){printf(\n=====Notstudentrecord!\n);getchar();return;}printf(\n\n);printheader();/*输出表格头部*/while(p)/*逐条输出链表中存储的学生信息*/{printdata(p);p=p-next;/*移动至下一个结点