学生选修课选课系统程序设计报告.doc

上传人:文库蛋蛋多 文档编号:2385928 上传时间:2023-02-17 格式:DOC 页数:51 大小:1.41MB
返回 下载 相关 举报
学生选修课选课系统程序设计报告.doc_第1页
第1页 / 共51页
学生选修课选课系统程序设计报告.doc_第2页
第2页 / 共51页
学生选修课选课系统程序设计报告.doc_第3页
第3页 / 共51页
学生选修课选课系统程序设计报告.doc_第4页
第4页 / 共51页
学生选修课选课系统程序设计报告.doc_第5页
第5页 / 共51页
点击查看更多>>
资源描述

《学生选修课选课系统程序设计报告.doc》由会员分享,可在线阅读,更多相关《学生选修课选课系统程序设计报告.doc(51页珍藏版)》请在三一办公上搜索。

1、湖南财政经济学院课程设计报告课 程面向对象程序设计和数据库开发技术题 目学生选修课选课系统专 业经济信息管理班 级2010级经济信息管理班姓 名易霜学 号2010050558指导教师蒋望东2011年12月20日课程设计成绩评定表系别:信息管理系 专业:2010级经济信息管理班学 号2010050558姓 名易霜论文(设计)题目学生选修课选课系统评定成绩项目 评判标准 (在每一项目对应的标准下方空格内标记)优秀 良好 中等 及格 不及格 工作量能很好地完成任务书规定的工作量。能较好地完成任务书规定的工作量。按时完成任务书规定的工作量。基本完成任务书规定的工作量。没有完成任务书规定的工作量。资料收

2、集方案设计独立提出实施方案,有分析整理、获取新知识的能力。能阅读一些自选资料,能较好地分析整理各类信息。能分析整理各类信息。能阅读教师指定的参考资料。未完成教师指定的参考资料的阅读。综合应用能力能熟练掌握和运用基本理论,取得的结果有一定的实用价值。能熟练掌握和运用有关理论,能独立取得结果。 较好地掌握有关理论,在教师指导下能完成工作。掌握和运用理论比较符合要求。基本理论模糊不清,无任何结果。能力技术水平设计合理,有较强的实际动手能力和计算机应用能力。设计比较合理、有一定的实际动手能力和计算机应用能力。设计比较合理,实际动手尚可。设计基本合理,理论分析与实施无大错。设计不合理,实际动手能力差。报

3、告撰写质量结构严谨,逻辑性强,层次清晰,文字流畅,符合规范化要求,打印精美。结构合理,符合逻辑,文章层次分明,语言准确,达到规范化要求,打印工整。结构基本合理,层次较分明,文理通顺,基本达到规范化要求。结构基本合理,文字尚通顺,勉强达到规范化要求。结构混乱,文字表达不清,错别字较多,达不到规范化要求。实习态度态度认真,作风严谨,严格按进度开展各项工作。实习态度比较认真,能按期圆满完成任务书规定的任务。遵守纪律,基本保证设计时间,按期完成各项工作。态度尚可,在指导教师的帮助下能按期完成任务。纪律涣散,不能保证设计时间和进度。评语: 指导老师: 年月日目录1引言32 需求分析42.1 系统需求42

4、.2 功能需求42.3 性能需求43 总体设计63.1 设计思想与处理流程63.2 系统层次模块图63.3 模块设计74 数据库设计95 详细设计135.1登录模块的设计与实现135.2 主操作页面效果175.3学生信息管理模块的设计与实现196 总结487 参考文献498.致谢501引言 “选课”是现在高校行政管理工作中一项很重要的课题。而且是每个学期都必须要面对的问题。选课工作做不好,学生不知道自己将要学习的课程,老师也不知道自己将要讲授的课程,教务处的排课计划、教室安排等其他调度工作也无从做起。因此,如何解决高校教务管理中的选课工作便成为了如今各大高校面临的很实际的问题。 随着科学技术的

5、不断提高,计算机科学日渐成熟,其强大的功能已为人们深刻认识,它已进入人类社会的各个领域并发挥着越来越重要的作用。应用计算机对高校教务信息工作进行辅助,具有人工管理所无法比拟的优点。例如:检索迅速,查找方便,可靠性强,存储量大,保密性能好等。这些优点能够极大地提高教务工作的质量和效率,也是高校教务工作科学化,规范化,信息化管理的重要条件。因此,开发在线选课系统很有必要。本系统的目标在于:(1)通过学生选修课系统的实现,使学校对学生选修课信息的管理规范化; (2)学生更加方便地查询自己的相关选课信息;(3)对不同身份的人群提供不同的权限。2 需求分析2.1 系统需求在各大中专院校,学校的教务管理的

6、主要内容包括学生的信息管理和教师排课,学生对于课程的选修以及老师授课尤为重要。本系统不仅是对学生信息的管理,也可以对教师信息进行管理。本系统不包含教师排课管理和教师管理的详细业务,只提供学生和教师选课及授课相关信息的查询。2.2 功能需求根据上述的信息管理系统的业务流程、要求以及所要实现的目标,我们可以拟出以下需求目标:(1)建立学生信息的管理和维护。实现计算机自动化管理体制。(2)建立学生选课管理机制,在计算机的支持下快速的完成学生选修课的查询和修改。(3)建立课程设置管理,在计算机的支持下实现课程的添加、删除、修改。(4)实现系统的多权限设置管理,保证系统安全性。根据系统的需求分析,得到本

7、系统的功能要求如下:(1)课程的设置管理:学校的教务秘书可以根据本校具体情况在每学期所开设的课程进行设置和修改。(2)权限管理:为了很好的保证系统的安全性,学校相关负责人可以设置管理员、教师以及学生三种类型的人员的权限。(3)学生信息管理:学生信息的数量十分庞大,教务管理人员进行新生选修课的档案录入及更改。其中包括学生个人信息的修改。(4)学生选课管理:教务管理人员可以查询和修改学生的所选课程,掌握学生学习情况,作为评定学生素质的数据依据。2.3 性能需求系统的运行对于运行环境的要求是;1硬件环境目前,我们所开发的系统主要是应用在中小规模的学校内部,因此,一般配置的计算机硬件就可以满足系统需求

8、。考虑到学校规模的扩大和硬件价格的降低,为本系统配置在较优秀的服务器硬件,可以充分发挥本系统性能。l 处理器: Intel Pentium 4 3.06 GX 或更高l 内存: 256M(推荐)l 硬盘空间:40GBl 显卡: SVGA显示适配器2软件环境l 操作系统:Windows 2000/XPl 开发软件:Microsoft Visual Studio .NET 2005l 数据库:Microsoft SQL Server 20053 总体设计3.1 设计思想与处理流程本系统采用面向对象方法进行分析和设计,在SQL Server 2000/XP数据库上实现数据操作。使用纯面向对象的C语言

9、作为开发语言,使用Windows2000/XP作为开发平台,能够很好的实现系统的开发及测试。系统的基本流程是:用户登陆主界面选择各项子系统。3.2 系统层次模块图“学生选修课系统”主要分为登录、用户信息、学生信息管理、课程信息管理、学生选课管理、关于本系统、学生选课相关信息、教师授课相关信息多个模块。系统主模块功能树如图2-1所示:学生选修课系统用户登录用户信息学生信息管理课程信息管理学生选课管理关于本系统学生选课信息教师授课信息 图2-1 “学生信息管理系统”系统主模块功能树3.3 模块设计1用户登录模块:输入用户名称和密码,选择用户身份,如果用户名、密码正确,身份恰当,进入主控制平台;否则

10、给出错误信息提示。2学生信息管理模块: 添加学生信息子模块:可以进行学生学号、姓名、年龄、性别、系别的添加。 删除学生信息子模块:方便教务管理人员删除某些学生。有利于管理人员随时掌握学生最新信息。 修改学生信息子模块:教务管理人员可以随时更改学生的某些信息,包括学生学号、姓名、年龄等信息的更改。 退出学生信息子模块:教务管理人员可以退出本模块进入下一模块。3用户信息管理模块: 显示所有用户子模块:教务管理人员课可以直接看到所有用户信息,包括管理员自己、学生以及教师。 清除结果子模块:可以直接将所有用户信息全部清空。4课程信息管理模块: 添加课程信息子模块:可以进行课程编号、名称、学分、开课学期

11、、总学时的添加。 删除课程信息子模块:方便教务管理人员删除某些课程及相关信息。 修改课程信息子模块:教务管理人员可以随时更改课程的某些信息,包括课程编号、名称、学分、开课学期、总学时信息的更改。 退出课程信息子模块:教务管理人员可以退出本模块进入下一模块。5关于本系统模块6学生选课模块: 选课子模块:点击“选择学生”“选择查询”,进行选课。 查询信息子模块:在“查询内容”中选择学号或者课程号,并输入查询值,进行查询。4 数据库设计4.1 SQL Server2000数据库建立过程首先把SQL Server 2000的“服务管理器”打开,鼠标左键单击“开始/继续”按钮,然后在“开始”“程序”内选

12、择“Microsoft SQL Server 2005” “Microsoft SQL Server Management Studio”。展开左边的程序树,如图2-1示。在“数据库”文件夹图标上单击鼠标右键,选择“新建数据库”,弹出新建数据库窗体,如图2-2示。在“名称”文本框内,输入新建数据库的名称,在此输入“stu_selectcourse”,新建学生信息管理数据库。其他选项默认即可。然后,开始建立本系统需要的数据库表,方法如下:首先,在新建的数据库上单击鼠标右键,选择“新建”“表”,如图2-3示。然后,在弹出的窗体内输入表字段和类型以及长度和是否允许空等信息,如图2-4示。输入完表字段

13、后,为表的字段添加主键、约束和关系等,方法是在添加约束或关系的字段上单击鼠标右键,选择“设置主键”或“关系”等。保存该表,命名为 “stu_information”。接下来在建立本章需要的其他表,在此不再详述了。接下来就是如何向已经建立好的数据表内输入数据了,方法如下,首先在建立好的表上单击鼠标右键,选择“打开表”“返回所有行”。然后在弹出的窗体内输入数据,输入结束后,鼠标左键单击工具栏上的运行图标,保存数据,如图2-5示。4. 2表结构实现根据系统功能设计的要求以及功能模块的划分,对于系统用户信息数据库,可以列出以下数据项和数据结构:(1)、名称:学生信息表表名称标识:stu_informa

14、tion表数据来源:学生信息管理模块进行录入。 (2)、名称:课程信息表表名称标识:Course_information表数据来源:课程信息管进行录入(3)、名称:用户信息表表名称标识:tbl_user表数据来源:用户信息管理模块进行录入。(4)、名称:选课信息管理表表名称标识:selectcourse表数据来源:选课信息管理进行录入。(5)名称:教师信息表表名称标识:teacher表数据来源:教师信息模块进行录入5 详细设计本系统主要实现学生选课信息的浏览、查询、编辑、添加和删除,同时对课程信息进行管理,增加权限的管理。根据已有的需求分析和总体设计,我们在此基础上来进行系统的详细设计和实现,

15、为此,我们建立了一个C.NET项目。在“开始”菜单中找到“Microsoft Visual Studio 2005”,启动应用程序,鼠标单击“文件” “新建” “项目”,单击“Visual C#项目”,建立一个“Windows应用程序”,命名为“Stu_selectcourse”,位置默认。如下图示。然后我们把这个项目生成的默认窗体作为本系统的主窗体,我们再向这个项目中添加一个窗体,鼠标单击“项目”“添加Windows窗体”,输入窗体名称为“frmLogin”把新添加的窗体作为登陆窗体,调整窗体大小到合适值。修改该窗体的name属性为“frmLogin”,text属性为“用户登录”,Start

16、Position属性为“CenterScreen”,其他属性默认。我们接下来的所有窗体文件都是使用这种方法在这个项目中添加。5.1登录模块的设计与实现1用户身份验证IPO图输入:用户名、密码和身份。处理:(1) 用户登录窗体启动。(2) 输入用户名和密码,选择身份。(3) 从用户信息表中检查是否有相应的用户名和密码以及身份是否正确。(4) 如果用户名或密码为空或者错误,进行提示。(5) 如果输入的用户名和密码正确,则允许该用户进入系统。(6) 进入主控制平台。输出:主控制平台。2用户登录模块的窗体设计,如下图所示:用到的主要控件是:Label、Button、TextBox、ComboBox该窗

17、口主要功能是登录功能,输入管理权限、用户名、密码登陆界面。次模块供不同用户登录使用,登录用户有管理员和学生3用户登录模块的主要代码using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Data.SqlClient;using System.Drawing;using System.Text;using System.Windows.Forms;namespace Stu_selectcourse public partial class f

18、rmLogin : Form public frmLogin() InitializeComponent(); private void txtUserName_KeyDown(object sender, KeyEventArgs e) if (e.KeyCode = Keys.Enter) txtUserPassword.Focus(); private void txtUserPassword_KeyDown(object sender, KeyEventArgs e) if (e.KeyCode = Keys.Enter) userPurview.Focus(); private vo

19、id userPurview_KeyDown(object sender, KeyEventArgs e) if (e.KeyCode = Keys.Enter) btnOk_Click_1(sender, e); private void btnOk_Click_1(object sender, EventArgs e) try DataSet ds = new DataSet(); DataBase db = new DataBase(); string sqlStr = select userPassword,userPurview from tbl_User where UserNam

20、e= + txtUserName.Text.Trim() + ; ds = db.GetDataFromDB(sqlStr); if (ds.Tables0.Rows0.ItemArray0.ToString().Trim() = txtUserPassword.Text.Trim() if (ds.Tables0.Rows0.ItemArray1.ToString().Trim() = 管理员) frmMain ob_menuStrip1 = new frmMain(); ClassShared.userInfo0 = txtUserName.Text.Trim(); ClassShared

21、.userInfo1 = ds.Tables0.Rows0.ItemArray1.ToString(); ob_menuStrip1.Show(); this.Hide(); if (ds.Tables0.Rows0.ItemArray1.ToString().Trim() = 学生) frmMainStudent ob_FrmMainStudent = new frmMainStudent(); ClassShared.userInfo0 = txtUserName.Text.Trim(); ClassShared.userInfo1 = ds.Tables0.Rows0.ItemArray

22、1.ToString(); ob_FrmMainStudent.Show(); this.Hide(); if (ds.Tables0.Rows0.ItemArray1.ToString().Trim() = 教师) frmMainTeacher ob_FrmMainTeacher = new frmMainTeacher(); ClassShared.userInfo0 = txtUserName.Text.Trim(); ClassShared.userInfo1 = ds.Tables0.Rows0.ItemArray1.ToString(); ob_FrmMainTeacher.Sho

23、w(); this.Hide(); else MessageBox.Show(用户名或密码错误, 提示); txtUserName.Text = ; txtUserPassword.Text = ; txtUserName.Focus(); catch (Exception ex) MessageBox.Show(用户名或密码错误,请重新输入! + ex.Message, 提示); private void btnClose_Click_1(object sender, EventArgs e) Application.Exit(); private void frmLogin_Load(ob

24、ject sender, EventArgs e) 管理员信息系统5.2 主操作页面效果1主控制平台的窗体设计,如下图所示:2.主控制平台的主要代码:using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Data.SqlClient;using System.Drawing;using System.Text;using System.Windows.Forms;namespace Stu_selectcourse public parti

25、al class frmMain : Form public frmMain() InitializeComponent(); private void 登录界面ToolStripMenuItem_Click(object sender, EventArgs e) frmLogin obj_FrmLogin = new frmLogin(); obj_FrmLogin.Show(); private void 用户信息管理ToolStripMenuItem_Click(object sender, EventArgs e) frmUserInfo obj_FrmUser = new frmUs

26、erInfo(); obj_FrmUser.Show(); private void 课程信息管理ToolStripMenuItem_Click(object sender, EventArgs e) frmCourse obj_FrmCourse = new frmCourse(); obj_FrmCourse.Show(); private void 关于本系统ToolStripMenuItem_Click(object sender, EventArgs e) frmAbout obj_FrmAbout = new frmAbout(); obj_FrmAbout.Show(); pri

27、vate void 选课信息管理ToolStripMenuItem_Click(object sender, EventArgs e) frmSC obj_FrmSC = new frmSC(); obj_FrmSC.Show(); private void 退出ToolStripMenuItem_Click(object sender, EventArgs e) Application.Exit(); private void 学生选课系统ToolStripMenuItem_Click(object sender, EventArgs e) this.Text = ClassShared.u

28、serInfo0 + - + ClassShared.userInfo1; private void 学生信息管理ToolStripMenuItem_Click_1(object sender, EventArgs e) frmStudent obj_FrmStudent = new frmStudent(); obj_FrmStudent.Show(); 5.3学生信息管理模块的设计与实现学生信息管理模块负责登录用户录入学生信息并对其进行添加、修改、删除等动作。(1)学生信息管理模块实现的功能学生管理模块主要实现录入并修改学生信息。(2)学生信息管理模块实现的效果学生信息管理模块的窗体设计效

29、果如下图所示。1).增加新的学生信息功能:在学生信息表中增加新的学号、姓名、性别、年龄和系别,并把结果写入到数据库stu_selectcourse内的stu_information表中。输入:新学生的姓名和学号等信息处理:l 在数据库stu_selectcourse内的stu_information表内添加学生信息,显示到窗体的DataGridView 控件中。l 选择确定或者继续添加。输出:对学生表stu_information进行记录修改2).删除学生功能:在学生信息表中删除已有学生,并把结果写入到数据库内的stu_information表中。输入:选中一条学生记录处理:l 在数据库stu

30、_selectcourse内的stu_information表内检索学生信息,显示到窗体的DataGridView控件中。l 如果存在该学生信息,则把该学生信息记录从数据库stu_selectcourse内的stu_information表中删除。l 把数据表的改动记录到数据库内。输出:对学生信息表进行记录修改3).修改学生信息功能:在学生信息表中修改学生信息,包括学生姓名和学号等,并把结果写入到数据库内的stu_information表中。输入:选中一条学生记录,输入修改信息处理:l 在stu_selectcourse内的stu_information表内检索学生信息,显示到窗体的DataG

31、ridView 控件中。l 在DataGridView 控件中录入修改的学生信息。l 把对数据表stu_information的改动记录到数据库内。输出:对学生信息表进行记录修改(3)学生信息管理模块的主要代码:using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Text;using System.Windows.Forms;namespace Stu_selectcourse public pa

32、rtial class frmStudent : Form public frmStudent() InitializeComponent(); void ObjOpen() txtNo.Enabled = true; txtName.Enabled = true; txtAge.Enabled = true; cmbSex.Enabled = true; txtDept.Enabled = true; txtNo.Focus(); void ObjClose() txtNo.Enabled = false; txtName.Enabled = false; txtAge.Enabled =

33、false; cmbSex.Enabled = false; txtDept.Enabled = false; void Clear() txtNo.Text = ; txtName.Text = ; txtAge.Text = ; cmbSex.SelectedIndex = -1; txtDept.Text = ; void RefreshData() string comStr; DataBase db = new DataBase(); DataSet ds = new DataSet(); comStr = select SNo as 学号,SName as 姓名, Ssex as

34、性别,Sage as 年龄,sDept as 所在系from stu_information; /select * from tbl_Student; ds = db.GetDataFromDB(comStr); if (ds = null) MessageBox.Show(没有任何学生记录,请输入或检查记录是否存在!, 提示); else dgrdvStudent.DataSource = ds.Tables0; private void frmStudent_Load(object sender, EventArgs e) try ObjClose(); string comStr; Da

35、taBase db = new DataBase(); DataSet ds = new DataSet(); comStr = select Sno as 学号,Sname as 姓名, Ssex as 性别,Sage as 年龄,Sdept as 所在系from stu_information; /select * from tbl_Student; ds = db.GetDataFromDB(comStr); if (ds = null) MessageBox.Show(没有任何学生记录,请输入或检查记录是否存在!, 提示); else dgrdvStudent.DataSource =

36、 ds.Tables0; dgrdvStudent_RowHeaderMouseClick(null, null); catch (Exception ex) MessageBox.Show(ex.Message); private void btnClose_Click(object sender, EventArgs e) this.Hide(); private void dgrdvStudent_CellMouseClick(object sender, DataGridViewCellMouseEventArgs e) dgrdvStudent_RowHeaderMouseClick(sender, e);

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 建筑/施工/环境 > 项目建议


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号