VB学生学籍管理系统(共65页).doc

上传人:飞****2 文档编号:17081504 上传时间:2022-05-21 格式:DOC 页数:66 大小:391.50KB
返回 下载 相关 举报
VB学生学籍管理系统(共65页).doc_第1页
第1页 / 共66页
VB学生学籍管理系统(共65页).doc_第2页
第2页 / 共66页
点击查看更多>>
资源描述

《VB学生学籍管理系统(共65页).doc》由会员分享,可在线阅读,更多相关《VB学生学籍管理系统(共65页).doc(66页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、精选优质文档-倾情为你奉上毕 业 论 文 (设 计)题 目 学生学籍管理系统英文题目Students student status manages system院 系 信息科学与技术学院 专 业 计算机网络技术 姓 名 高望春 年 级 指导教师 专心-专注-专业目 录摘 要随着信息技术在管理上越来越深入而广泛的应用,管理信息系统的实施在技术上已逐步成熟。管理信息系统是一个不断发展的新型学科,任何一个单位要生存要发展,要高效率地把内部活动有机地组织起来,就必须建立与自身特点相适应的管理信息系统。 本文介绍了在Visual Basic6.0环境下采用“自上而下地总体规划,自下而上地应用开发”的策略

2、开发一个管理信息系统的过程。通过分析访客管理的不足,创建了一套行之有效的计算机管理学生的方案。文章介绍了访客管理信息系统的系统分析部分,包括可行性分析、业务流程分析等;系统设计部分主要介绍了系统功能设计和数据库设计及代码设计;系统实现部分说明了几个主要模块的算法, 本系统面友好,操作简单,比较实用。关键词:SQL 2000 server,VB程序设计,软件工程Abstract Along with information technique more and more thorough but extensive on the management of application, manage

3、 information system of the implement has been gradually mature on the technique.Manage the information system is a new academics which continuously develops, the whichever unit wants to exist to want adevelopment, high-efficiencily internal activity organically the organization get up, have to build

4、 up adapting with oneself characteristics mutually of management information system. This text introduced in the Visual Basic6.0 under the environments the strategy of adoptionfrom top to bottom total programming, from bottom but last pplication development develop a process which manage information

5、 system.Pass the shortage of analytical visitor management, established a valid a set of line a calculator a management the students project.The article introduced visitor a management information system of system analysis part, System realization part explained a few calculate ways of main mold pie

6、ce, this system interface amity, operation simple, more practical.Keyword:The SQL 2000 servers、 VB program design、software engineering第一章 系统需求分析伴随社会的高速发展,全国各高校的学生数量一直在增加,在这样的形式下,必须要求学校有一种高效有序的方法来管理学生的信息。通过调查,要求系统需要有以下功能: 由于操作人员的计算机知识普遍较差,要求有良好的人机界面; 由于该系统的使用对象多,要求有较好的权限管理; 原始数据修改简单方便,支持多条件修 方便的数据查询,

7、支持多条件查询; 在相应的权限下,删除数据方便简单,数据稳定性好; 数据计算自动完成,尽量减少人工干预;第二章 可行性分析由于本系统管理的对象单一,都是学生,且每个数据内容具有较强的关联性,涉及的计算过程不是很复杂。因此,比较适合于采用数据库管理。在技术难度方面,由于有指导老师的指导和相关参考文献,特别是网上资料,特别是参考其它程序的功能,因此完全可以实现。本系统的设计是在Windows XP操作系统环境下,使用Visual Basic 6.0中文版开发成功的。数据库是MIS中的重要支持技术,在MIS开发过程中,如何选择数据库管理是一个重要的问题,本系统选用的数据库语言介绍如下:Visual

8、Basic具有以下特点:(1)可视化编程:用传统程序设计语言设计程序时,都是通过编写程序代码来设计用户界面,在设计过程中看不到界面的实际显示效果,必须编译后运行程序才能观察。如果对界面的效果不满意,还要回到程序中修改有时候,这种编程-编译-修改的操作可能要反复多次,大大影响了软件开发效率。Visual Basic提供了可视化设计工具,把Windows界面设计的复杂性“封装”起来,开发人员不必为界面设计而编写大量程序代码。只需要按设计要求的屏幕布局,用系统提供的工具,在屏幕上画出各种“部件”,即图形对象,并设置这些图形对象的属性。Visual Basic自动产生界面设计代码,程序设计人员只需要编

9、写实现程序功能的那部分代码,从而可以大大提高程序设计的效率。(2)面向对象的程序设计4.0版以后的Visual Basic支持面向对象的程序设计,是应用面向对象的程序设计方法(OOP),把程序和数据封装起来作为一个对象,并为每个对象赋予应有的属性,使对象成为实在的东西。在设计对象时,不必编写建立和描述每个对象的程序代码,而是用工具画在界面上,Visual Basic自动生成对象的程序代码并封装起来。每个对象以图形方式显示在界面上,都是可视的。第三章 系统设计31.系统功能分析系统开发的总体任务是实现学生信息关系的系统化,规范化和自动化。 学生管理系统需要完成的功能主要有: 学生信息的输入,包括

10、输入学生基本信息、所在班级、所学课和 成 绩等。 学生信息的查询,包括输入学生基本信息、所在班级、已学课程和成绩 等。 学生信息的修改。 班级管理信息的输入、查询、修改,包括输入班级设置,年级信息等。 基本课程信息的输入、查询、修改。 学生成绩信息的输入、查询、修改。 对上述各功能进行集中、分块、按照结构化程序设计的要求。学生信息管理系统学籍管理功能班级管理功能课程管理功能成绩管理功能学籍添加学籍修改学籍查询班级添加课程添加课程修改课程查询成绩添加成绩修改成绩查询班级修改班级查询图3-1 系统功能模块图32.系统流程图 登录成功选择操作开始用户管理学籍管理班级管理课程设置成绩管理退出系统添加修

11、改查询结束NY图3-2 系统流程图第四章、数据库设计41.数据库需求分析 用户信息:包括的数据项有:用户名、密码、用户描述。 学生基本信息:包括的数据项有:学生学号、学生姓名、性别、出生日期、班号、联系电话、入校日期、家庭地址、备注等。 班级信息:包括的数据项有:班号、所在年级、班主任姓名、所在教室等。 课程基本信息:包括的数据项有:课程号、课程名称、课程类别、课程描述等。 课程设置信息:包括的数据项有:年级信息、所学课程等。 学生成绩信息:包括的数据项有:考试编号、所在班号、学生学号、学生姓名、所学课程、考试分数等。 学生管理系统用户信息学生基本信息班级信息课程基本信息年级课程 成绩信息 数

12、据库 图4-1 学生管理系统数据流程图42.数据库概念结构设计 本系统的实体有:学生实体、班级实体、年级实体、课程实体。各个实体具体的描述E-R图如图下所示。 学生基本信息班级成绩课程图4-2 学生实体ER图 班级所在年级班主任所在教室班号图4-3 班级实体ER图 课程名称编号描述类型 图4-4 课程实体ER图 年级包括班级设置课程课程图4-5 年级实体ER图 学生班级年级课程1nnnnmmnn111 图4-6 实体之间关系ER图 现在需要将上面的数据库概念结构转化为SQL Server 2000 数据库系统所支持的实际数据模型,也就是数据库的逻辑结构。学生管理系统数据库中各个表格的设计结果如

13、下面的几个表所示。每个表表示在数据库中的一个数据表表4-1 student-info学生基本信息表 表4-2 class-info班级基本信息表 表4-3 course-info 课程基本信息表 表4-4 gradecourse-info年级课程设置表格 表4-5 result-info学生成绩基本信息表 表4-6 user-info 系统用户表 43.数据库结构的实现 经过前面的需求分析和概念结构设计以后,得到数据库的逻辑结构。就可以在SQL Servr 2000数据库系统中实现该逻辑结构,利用SQL Server 2000数据库系统中SQL查询分析器实现的。(1)创建系统用户表格user_

14、infoCREATE TABLE dbo.user_Info (user_ID char (10) COLLATE Chinese_PRC_CI_AS NOT NULL ,user_PWD char (10) COLLATE Chinese_PRC_CI_AS NULL ,user_Des char (10) COLLATE Chinese_PRC_CI_AS NULL) ON PRIMARYGO(2)创建学生基本信息表格student_infoCREATE TABLE dbo.student_Info (student_ID int NOT NULL ,student_Name char (

15、10) COLLATE Chinese_PRC_CI_AS NULL ,student_Sex char (2) COLLATE Chinese_PRC_CI_AS NULL ,born_Date datetime NULL ,class_NO int NULL ,tele_Number char (10) COLLATE Chinese_PRC_CI_AS NULL ,ru_Date datetime NULL ,address varchar (50) COLLATE Chinese_PRC_CI_AS NULL ,comment varchar (200) COLLATE Chinese

16、_PRC_CI_AS NULL) ON PRIMARYGO(3)创建班级信息表格class-infoCREATE TABLE dbo.class_Info (class_No int NOT NULL ,grade char (10) COLLATE Chinese_PRC_CI_AS NULL ,director char (10) COLLATE Chinese_PRC_CI_AS NULL ,classroom_No char (10) COLLATE Chinese_PRC_CI_AS NULL) ON PRIMARYGO(4)创建课程基本信息表格course-infoCREATE T

17、ABLE dbo.course_Info (course_No int NOT NULL ,course_Name char (10) COLLATE Chinese_PRC_CI_AS NULL ,course_Type char (10) COLLATE Chinese_PRC_CI_AS NULL ,course_Des char (50) COLLATE Chinese_PRC_CI_AS NULL) ON PRIMARYGO(5)创建年级课程设置信息表gradecourse-infoCREATE TABLE dbo.gradecourse_Info (grade char (10)

18、COLLATE Chinese_PRC_CI_AS NULL ,course_Name char (10) COLLATE Chinese_PRC_CI_AS NULL) ON PRIMARYGO(6)创建学生成绩信息表result-infoCREATE TABLE dbo.result_Info (exam_No char (10) COLLATE Chinese_PRC_CI_AS NOT NULL ,student_ID int NOT NULL ,student_Name char (10) COLLATE Chinese_PRC_CI_AS NULL ,class_No int NU

19、LL ,course_Name char (10) COLLATE Chinese_PRC_CI_AS NULL ,result float NULL) ON PRIMARYGO第五章、详细设计51主窗体的创建 上面的SQL语句在SQL Server 2000中查询分析器执行后,将自动产生需要的所有表。有关数据库结构的所有后台工作已经完成。现在将通过学生管理系统中各个功能模块的实现,来编写数据库系统的客户端程序。1. 创建工程项目Student-MIS 为了用Visual Basic创建应用程序,应当使用工程。一个工程是用来建造应用程序的文件的集合,它包括: 跟踪所有部件的工程文件(.vbp)

20、。 每个窗体的文件(.frm)。 每个窗体的二进制数据文件(.frx),它含有窗体上控件的属性数据。对含有二进制属性的任何.frm文件都是不可编辑的,这些文件都是自动产生的。 每个类模块的一个文件(.cls),该文件是可选项。 每个标准模块的一个文件(.bas),该文件是可选项。 一个或多个包含ActiveX控件的文件(.ocx),该文件是可选项。 单个资源文件(.res),该文件是可选项。 启动Visual Basic后,单击File|New Project菜单,如图所示的工程模块中选择Standard EXE,Visual Basic将自动产生一个Form窗体,属性都是缺省设置。这里我们删

21、除这个窗体,单击File|New Project菜单,将这个工程项目命名为Student-MIS。 如图5-1: 创建Student-MIS项目 2.创建主窗体 Visual Basic创建的应用程序可以是SDI(单文档界面)和MDI(多文档界面)。在SDI的程序中,每个窗体之间是独立的。而MDI的程序中,有一个窗体是主窗体,可以包含其她窗体,它的类型是MDI Form。本系统采用多文档界面,这样可以使程序更加美观,整齐有序。 单击工具栏的“ADD MDI Form”按钮,生成一个如下所示的窗体, 图5-2 程序主窗体创建主窗体的菜单 : 图5-3主窗体中菜单结构3.创建公用模块 在Visua

22、l Basic中可以用共用模块来存放整个工程项目公用的函数、全局变量等。整个工程项目中的任何地方都可以调用公用模块中的函数、变量,这样可以极大地提高代码的效率。在项目资源管理器中为项目添加一个Module,保存为Module.bas。下面就可以开始添加需要的代码。 由于系统中各个功能模块都将频繁使用数据库中的各种数据,因此需要一个公共的数据操作函数,用以执行各种SQL语句。添加函数ExecuteSQL,代码如下:Public Function ExecuteSQL(ByVal SQL _As String, MsgString As String) _As ADODB.Recordset传递参

23、数SQL查询语句,MsgString传递查询信息自身以一个数据集对象的形式返回Dim n As ADODB.Connection定义连接Dim rst As ADODB.Recordset定义字符串Dim sTokens() As String异常处理On Error GoTo ExecuteSQL_Error用Split函数产生一个包含各个子串的数组sTokens = Split(SQL)创建连接Set n = New ADODB.Connectionn.Open ConnectString判断字符串中是否有指定内容If InStr(INSERT,DELETE,UPDATE, _UCase$

24、(sTokens(0) Then执行查询语句n.Execute SQL返回查询信息MsgString = sTokens(0) & _ query successfulElse创建数据集对象Set rst = New ADODB.Recordset返回查询结果rst.Open Trim$(SQL), n, _adOpenKeyset, _adLockOptimisticrst.MoveLast get RecordCountSet ExecuteSQL = rstMsgString = 查询到 & rst.RecordCount & _End IfExecuteSQL_Exit:清空数据集对象

25、Set rst = Nothing中断连接Set n = NothingExit Function错误类型判断ExecuteSQL_Error:MsgString = 查询错误: & _Err.DescriptionResume ExecuteSQL_ExitEnd Function ExecuteSQL函数有两了参数:SQL和MsgString。其中SQL用来存放需要执行的SQL语句,MsgString用来返回执行的提示信息。函数执行时,首先判断SQL语句中包含的内容。当执行查询操作时,ExecuteSQL函数将返回一个与函数同名的记录名对象(Recordset),所有满足条件的记录包含在对

26、象中。当执行如删除、更新、添加等操作时,不返回记录集对象。 在ExecuteSQL函数中使用Connect String函数,这个函数用来连接数据库,代码如下:Public Function ConnectString() _As String返回一个数据库连接ConnectString = FileDSN=studentinfo.dsn;UID=sa;PWD=End Function由于在后面的程序中,需要频繁检查各种文本框的内容是否为空,这里定义了Testtxt函数,代码如下:Public Function Testtxt(txt As String) As BooleanIf Trim(

27、txt) = ThenTesttxt = FalseElseTesttxt = TrueEnd IfEnd Function 由于学生管理系统启动后,需要对用户进行判断。如果登录者是授权用户,将进入系统,否则将停止程序的执行。这个判断需要在系统运行的最初进行,因此将代码放在公用模块中,代码如下:Public fMainForm As frmMainPublic UserName As StringSub Main()Dim fLogin As New frmLogin显示登陆窗体fLogin.Show vbModal判断是否授权用户If Not fLogin.OK ThenLogin Fail

28、ed so exit appEndEnd IfUnload fLoginSet fMainForm = New frmMainfMainForm.ShowEnd Sub过程Main将在系统启动是首先执行,这就保证对用户的管理。52.用户管理模块的创建系统管理模块主要实现: 用户登录。 添加用户。 修改用户密码。1.用户登陆窗体的创建系统启动后,将首先出现如下所示的用户登陆窗体,用户首先输入用户名,然后输入密码。如果用户3次输入密码不正确,将退出程序。 图5-4用户登录窗体 用户登陆窗体中放置了两个文本框(TextBox),用来输入用户名和用户密码。两个按钮(CommandButton)用来确定

29、或者取消登陆。2个标签(Label)用来标示窗体的信息。为窗体定义全局变量OK,用来判断登陆是否成功。定义 miCount,用来记载输入密码的次数。并且在载入窗体时初始化这两个全局变量,代码如下:强制变量声明Option ExplicitPublic OK As Boolean记录确定次数Dim miCount As IntegerPrivate Sub Form_Load()Dim sBuffer As StringDim lSize As LongsBuffer = Space$(255)lSize = Len(sBuffer)Call GetUserName(sBuffer, lSize

30、)If lSize 0 ThentxtUserName.Text = ElsetxtUserName.Text = vbNullStringEnd IfOK = FalsemiCount = 0End SubOption Explicit是用来规定所有变量使用前必须定义。这样可以避免由于输入错误而产生的新变量。当用户输入完用户名和用户密码,单击cmdOK按钮将对用户输入信息进行判断。用户单击该按钮,将触发按钮cmdOK的Click事件,代码如下:Private Sub cmdOK_Click()用来存放SQL语句Dim txtSQL As String用来存放记录集对象Dim mrc As A

31、DODB.Recordset用来存放返回信息Dim MsgText As StringUserName = 判断输入用户名是否为空If Trim(txtUserName.Text = ) ThenMsgBox 没有这个用户,请重新输入用户名!, vbOKOnly + vbExclamation, 警告txtUserName.SetFocusElsetxtSQL = select * from user_Info where user_ID = & txtUserName.Text & Set mrc = ExecuteSQL(txtSQL, MsgText)If mrc.EOF = True

32、ThenMsgBox 没有这个用户,请重新输入用户名!, vbOKOnly + vbExclamation, 警告txtUserName.SetFocusElse判断输入密码是否正确If Trim(mrc.Fields(1) = Trim(txtPassword.Text) ThenOK = Truemrc.CloseMe.HideUserName = Trim(txtUserName.Text)ElseMsgBox 输入密码不正确,请重新输入!, vbOKOnly + vbExclamation, 警告txtPassword.SetFocustxtPassword.Text = End If

33、End IfEnd If记载输入密码次数miCount = miCount + 1If miCount = 3 ThenMe.HideEnd IfExit SubEnd Sub用户如果没有输入用户名和用户密码,将出现消息框给予提示。如果输入的用户名在用户表格中没有找到,将提示重新输入用户名,文本框txtUserName将重新获得输入焦点。如果用户输入的密码不正确,文本框txtPassword将重新获得输入焦点。用户登陆成功,全局变量OK将被赋值为True。一旦三次输入密码均不正确,全局变量OK将被赋值为False。公用模块中的Main过程将根据OK的值决定是退出,或者进入系统。如果用户取消登陆

34、,单击“取消”按钮,将触发按钮的Click事件,代码如下:Private Sub cmdCancel_Click()OK = FalseMe.HideEnd Sub2.添加用户窗体的创建 进入系统后,选择菜单“系统添加用户”就可以添加用户,出现如下所示的窗体。 图5-5 添加用户窗体用户需要两次输入密码,用来确保输入密码的正确。用户输入信息完毕,单击“确定”按钮将触发Click事件,代码如下:Private Sub cmdOK_Click()Dim txtSQL As StringDim mrc As ADODB.RecordsetDim MsgText As String判断是否为空If T

35、rim(Text1(0).Text) = ThenMsgBox 请输入用户名称!, vbOKOnly + vbExclamation, 警告Exit SubText1(0).SetFocusElsetxtSQL = select * from user_Info Set mrc = ExecuteSQL(txtSQL, MsgText)判断数据集是否为空While (mrc.EOF = False)判断是否有重复记录If Trim(mrc.Fields(0) = Trim(Text1(0) ThenMsgBox 用户已经存在,请重新输入用户名!, vbOKOnly + vbExclamatio

36、n, 警告Text1(0).SetFocusText1(0).Text = Text1(1).Text = Text1(2).Text = Exit SubElsemrc.MoveNextEnd IfWendEnd If判断两次输入密码是否一致If Trim(Text1(1).Text) Trim(Text1(2).Text) ThenMsgBox 两次输入密码不一样,请确认!, vbOKOnly + vbExclamation, 警告Text1(1).SetFocusText1(1).Text = Text1(2).Text = Exit SubElse判断输入密码是否为空If Text1(

37、1).Text = ThenMsgBox 密码不能为空!, vbOKOnly + vbExclamation, 警告Text1(1).SetFocusText1(1).Text = Text1(2).Text = Elsemrc.AddNewmrc.Fields(0) = Trim(Text1(0).Text)mrc.Fields(1) = Trim(Text1(1).Text)mrc.Updatemrc.CloseMe.HideMsgBox 添加用户成功!, vbOKOnly + vbExclamation, 添加用户End IfEnd IfEnd Sub 一旦输入完毕,系统将首先查询数据库

38、中与新建用户名相同的记录,如果有相同记录将提示用户重新输入用户名。当确定数据库中没有相同的用户名,并且两次输入密码一致时,将把该条记录加到数据库中。单击“取消”按钮将取消添加用户操作,代码如下:Private Sub cmdCancel_Click()Unload MeEnd Sub3.修改用户密码窗体的创建用户可以修改自己的密码,选择菜单“系统修改密码”,出现如下所示的窗体。 图5-6 修改密码窗体在这两个窗体中放置了两个文本框,用来输入密码和确认密码。两了按钮用来确定是否修改密码。两个标签用来标示文本框的内容。两次输入密码后,单击“确认”按钮,将触发Click事件判断是否修改密码,代码如下

39、:Private Sub cmdOK_Click()Dim txtSQL, MsgText As StringDim mrc As ADODB.Recordset判断是否为空If Trim(Text1(1).Text) Trim(Text1(2).Text) ThenMsgBox 密码输入不正确!, vbOKOnly + vbExclamation, 警告Text1(1).SetFocusText1(1).Text = ElsetxtSQL = select * from user_Info where user_ID = & UserName & Set mrc = ExecuteSQL(t

40、xtSQL, MsgText)mrc.Fields(1) = Text1(1).Textmrc.Updatemrc.CloseMsgBox 密码修改成功!, vbOKOnly + vbExclamation, 修改密码Me.HideEnd IfEnd Sub当两次输入密码一致时,数据库中的记录将更新。53学籍管理模块的创建学籍信息管理模块主要实现如下功能: 添加学籍信息 修改学籍信息 查询学籍信息1.添加学籍信息窗体的创建 选择“学籍管理|添加学籍信息”菜单,将出现如下的窗体; 图5-7 添加学籍信息窗体 在窗体上放置多个文本框和下拉式文本框,用来输入学籍信息。两个按钮用来确定是否添加学籍信息

41、。多个标签用来提示文本框中需要输入的内容。 在载入窗体时,程序将自动在两个下拉式文本框中添加内容,这样可以规范化输入内容,代码如下:Private Sub Form_Load()Dim mrc As ADODB.RecordsetDim txtSQL As StringDim MsgText As StringDim i As Integer添加列表框内容comboSex.AddItem 男comboSex.AddItem 女txtSQL = select * from class_Info Set mrc = ExecuteSQL(txtSQL, MsgText)添加内容到列表框中For i

42、 = 1 To mrc.RecordCountcomboClassNo.AddItem mrc.Fields(0)mrc.MoveNextNext imrc.CloseEnd Sub在班号选择的下拉式文本框中,将出现所有班级,用户不用输入内容。用户输入内容完毕后,单击按钮cmdOK将触发Click事件,代码如下:Private Sub cmdOK_Click()定义数据集对象Dim mrc As ADODB.Recordset定义字符串变量,表示查询语句Dim txtSQL As String定义字符串变量,返回查询信息Dim MsgText As String判断是否输入学号If Not Testtxt(txtSID.Text) ThenMsgBox 请输入学号!, vbOKOnly + vbExclamation, 警告txtSID.SetFocusExit SubEnd If判断是否输入姓名If Not Testtxt(txtName.Text) Then

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

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

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁