学生成绩管理系统的设计与实现毕业论文

上传人:1777****777 文档编号:36994439 上传时间:2021-11-01 格式:DOC 页数:29 大小:966.03KB
返回 下载 相关 举报
学生成绩管理系统的设计与实现毕业论文_第1页
第1页 / 共29页
学生成绩管理系统的设计与实现毕业论文_第2页
第2页 / 共29页
学生成绩管理系统的设计与实现毕业论文_第3页
第3页 / 共29页
点击查看更多>>
资源描述
廊坊职业技术学院高职计算机类廊坊职业技术学院高职计算机类毕业(设计)论文毕业(设计)论文 计算机科学与工程系计算机科学与工程系专业专业题目 学生成绩管理系统的设计与实现学生成绩管理系统的设计与实现 学生姓名学生姓名 学学 号号 10130800351013080035 指导教师指导教师 班班 级级 信管信管 G1001G1001 目录摘摘 要要.3一、一、开发目标及开发意义开发目标及开发意义.5 二、系统分析二、系统分析.7(一一)学生成绩管理系统概述学生成绩管理系统概述.7(二二) 需求分析需求分析.81) 功能需求分析功能需求分析.82) 性能需性能需求求分析分析.93)数据库需求分析)数据库需求分析数据流图数据流图.94)数据结构分析数据结构分析数据流图数据流图.10(三三)系统功能结构设计系统功能结构设计.12三、三、系统设计系统设计.13(一一)设计目标设计目标.13(二二)开发及运行环境开发及运行环境.13(三三)数据库设计数据库设计.14四、系统的实现四、系统的实现.17(一一)学生查询成绩部分学生查询成绩部分.17(二二)后台管理成绩部分后台管理成绩部分.19 登陆模块登陆模块.19 年纪班级管理模块年纪班级管理模块.20 课程管理模块课程管理模块.24 评分模块评分模块.24 学生信息管理模块学生信息管理模块.27 管理员模块管理员模块.29 五、总结五、总结参考文献参考文献.30摘要摘要在现在,高科技的飞跃发展,计算机的大量普及,使得人们生活节奏越来越快。因此对教育行业的多元信息进行有效的管理工作,也成为教育行业中的重中之重。目前,学校工作复杂、资料众多,虽然各类管理信息系统已进入高校,但还未普及,而对于学生成绩管理来说,目前还没有一套完整的、统一的系统。为各高校教务工作人员减轻负担,提高工作效率,所以制作了学生成绩管理系统。关键词:关键词:java,SQL ,TOMCAT,学生成绩管理AbstractAlong with the modern computer science development, the computer information system is more and more important, the network already became the people to exchange the information important way, therefore appeared systems that based on network platform, the B/S system already became one kind of important tool which the people exchanged. Now we will introduce how to use java and RIA to develop a student score management system. This part including database creation and the system function realization. Finally expound the matter and shortage of the system, in order to ameliorate better in the future.Keywords: java, SQL, TOMCAT,Student score management一、一、开发目标及开发意义开发目标及开发意义1、开发目标 本系统是针对学生成绩管理系统的设计,而且学生查询以及教师查询都比较方便,系统中提供了管理员管理用户的平台,教师可对学生基本信息以及学生成绩等进行查询,学生可对学生基本信息、课程信息、班级信息以及学生成绩等进行查询。 使用廊坊职业技术学院的学生管理系统可进行如下操作: (1) 可对用户和学生信息及权限进行管理。 (2) 老师可对学生成绩进行添加、删除、修改等操作。 (3) 可对学生的成绩进行查询。 (4) 可对学生成绩或学生信息等进行报表打印和统计功能。 (5) 具有查询帮助环境。2、开发意义采用计算机对学生成绩进行管理,可以进一步提高办学效益和现代化水平。帮助广大教师提高工作效率,实现学生成绩信息管理工作流程的系统化、规范化和自动化。运用学生成绩管理系统可以减轻学校教学人员的工作量,节约成本,提高工作效率与准确率,能够合理安排时间,能够尽快的知道自己的考试成绩,投入新的课程的学习或复习这次有考过的课程。而学生成绩管理系统的应用也为今天的民办教育在未来市场的竞争力有所提高。从大的方向说,就是为了加速我国四化建设的发展,实现全部的自动化,是我国成为通讯网络化、决策科学化。办公自动化的国家。在高科技的飞跃发展的现在,人们工作习惯的改变,特别是电脑的大量普及,人们生活节奏越来越快,怎样提高工作效率是人们首先考虑的问题。学生成绩管理是个非常繁琐与复杂的一项工作,一个原因就是工作量大、任务重。对于一个学校而言,更应该有效地运用一些本地资源,提高管理的力度。二、二、系统分析系统分析( (一一) )学生成绩管理系统概述学生成绩管理系统概述1)学生成绩管理系统的发展背景学生成绩管理是各大学的主要日常管理工作之一,涉及到校、系、师、生的诸多方面,随着教学体制的不断改革,尤其是学分制、选课制的展开和深入,学生成绩日常管理工作及保存管理日趋繁重、复杂。迫切需要研制开发一款功能强大,操作简单,具有人性化的学生成绩管理系统。目前研究的现状在安全性和信息更新化方面存在有一定的不足,各现有系统资料单独建立,共享性差;在以管理者为主体的方式中,信息取舍依赖管理者对于信息的认知与喜好,较不容易掌握用户真正的需求,也因此无法完全满足用户的需求。因此,教务管理软件应充分依托校园网,实现教务信息的集中管理、分散操作、信息共享,使传统的教务管理朝数字化、无纸化、智能化、综合化的方向发展,并为进一步实现完善的计算机教务管理系统和全校信息系统打下良好的基础。随着计算机及网络技术的飞速发展,Internet/Intranet 应用在全球范围内日益普及,在众多的网络服务中,Web 给人耳目一新的感觉,而在这其中,网络已经日渐普及,任何人可以在网络所提供的平台上进行自由的交流,通过网络,学生可以通过在线的网络直接查询程序,而学校教师也可在网上在线管理学生的成绩,不需要再去张贴成绩单,使用了在线电子系统,既便于数据查询不容易使数据丢失,又省去了印刷张贴的麻烦,可谓一举两得。B/S 系统得益于网络的兴起,采用浏览器作为前端用户操作的平台,所有的操作系统都预装了网络浏览器,比如 IE,用户不用再去费心安装每个系统的客户端就可以通过浏览器访问服务器上架设的系统只是随着网络的发展,人们不再局限于只查看文字信息图片这些静态信息,对 B/S系统的互操作性有了进一步的需求,这才兴起了 RIA 富客户端的风潮,使用各种技术对浏览器进行功能上的增强,让它可以满足现代用户的需要。这套学生成绩管理系统,就是基于 java 平台和 ajax 实现的 RIA 富客户端开发的,它包括学生查询平台和后台管理平台两部分,分别为学生提供成绩查询功能,为老师提供管理学生成绩的功能。2)方案论证 成绩管理系统是典型的信息管理系统(MIS),其开发主要包括后台数据库的建立和维护以及前端应用程序的开发两个方面。对于前者要求建立起数据一致性和完整性强、数据安全性好的库。而对于后者则要求应用程序功能完备,易使用等特点。本系统主要完成对学生成绩的管理,包括数据库中表的添加、修改、删除等。系统还可以完成对各类信息的浏览、查询、添加、删除、修改等功能。3) 开发工具的选择本系统开发工具:JDK Version1.5+ SQL SERVER 2000( (二二) )需求分析需求分析1) 功能需求分析 该学生成绩管理系统具备三方面的功能:一方面是学生用户,学生通过输入学号和密码进下该系统后,可以进行一些基础查询(学生信息查询、班级信息查询、课程信息查询) 、成绩管理(成绩查询、计算平均分)重新登陆系统;一方面老师进入该系统则比学生多一些权限:成绩输入、成绩查询。具体功能的详细描述如下1 选择学生基本维护菜单命令,即可进入 学生基本维护功能窗体,在其中输入学生的相关信息,如果需要添加或修改学生信息,则单击相应的按纽,输入新信息后单击添加就可以了。需要删除一条信息,则只要选择这条信息再点击 删除。在搜索条件中输入相关的条件,单击 查询就可查找信息。2 选择学生信息查询菜单命令,即可进入学生信息查询功能窗体,在其中的下拉列表中选择你要看的信息,则在下面的表格中显示你要的信息。3 选择成绩管理 添加成绩菜单命令,即可进入 添加成绩功能窗体,此功能权限只有管理员和教师。4 选择成绩管理 输入成绩菜单命令,即可进入 输入成绩功能窗体,此功能权限只有管理员和教师。5 选择成绩管理 修改成绩 界面,此功能规管理员所有。6 选择成绩管理 查询成绩界面此界面对学生也是可见的,它的权限规所有用户所有。7 选择登陆 重新登陆 则会返回登陆界面,为用户提供方便。8 选择退出将退出整个系统。2) 性能需求分析时间特性要求:在软件方面,响应时间有点慢,因为是用 JBuilder 做的,它占用内存比较大,更新处理时间比较快而且迅速。安全性:设立口令号和密码验证方式,防止非法用户登录进行操作。也就是用户只有管理员、学生和教师才能进入这个系统,用户凭口令号和密码进入此系统,系统会自动判断用户是那种类型,分别拥有不同的权限。3) 数据库需求分析数据流图在教务系统中功能模块主要牵涉到的信息包括:是学生信息(base_info) 、班级信息(class_info)、课程信息(class_info)、成绩表(chengjibiao)、选课表 (xuankebiao)、登陆表(stu)。学生信息:包含学号(id)、姓名(name)、班级(class)、班级(grade) 、性别(sex)课程信息:包括课程编号(course_id)、课程名称(coursename)姓名(name)、成绩(result) 成绩表:编号(number)、学号(id)、课程名称(coursename)、成绩(result)班级信息:班级编号(bjbh)、学号(id)、姓名(name)、班级名称(bjmc)。登陆表:口令号(id)、密码(password)。根据以上划分的具体数据信息,得到数据流图如 1.1 所示: 用 户登 录操 作登陆信息错误信息寻找信息数 据 库1.1 数据库需求分析数据流图4)数据结构分析学生信息=组成: 学号(id)、姓名(name)、班级(class)、性别(sex)、地址(address)课程信息=组成: 编号(course_id)、课程名称(coursename)、教师(teacher)选课信息=组成:编号(select_id) 课程名称(coursename)、课程编号(course_id)、学号(xh)、姓名(name)、成绩(result) 、教师(teacher)成绩表包括=组成:编号(number)、学号(id)、课程名称(coursename)、成绩(result)、教师(teacher) 课程信息包括=组成:课程编号(course_id)、课程名称(coursename)、教师(teacher)班级信息=组成:班级编号(bjbh)、年级(nj)、班级名称(bjmc)、人数(rs)、班主任(bzr)登陆表=组成:口令号(id)、密码(password)、权限(rightlimit)1 1、对图、对图 1.11.1 中所涉及的数据流描述如下:中所涉及的数据流描述如下:1) 数据流名:口令号说明:根据这个口令号定位到用户管理数据库,以便进行身份验证。数据流来源:登陆界面输入的口令号和密码。数据流去向:其中用户口令信息将存在于整个操作过程中,防止非法登陆。数据流组成:口令号(文本) ;密码(文本)2)数据流名:寻找信息说明:根据用户在学生信息维护的时候所填写的信息。数据流来源:学生信息维护界面学生输入包含学号、班级编号、名称等。数据流去向:学号将存在整个操作,其它的存入数据库。数据流组成:学号(文本) ;姓名(文本)等3)数据流名:寻找信息说明:根据用户在成绩管理的时候所填写的信息。数据流来源:成绩输入、修改、添加等界面用户输入包含课程编号、课程名称、成绩、教师。数据流去向:学号、班级编号、课程编号将存在整个操作,其它的存入数据库。数据流组成:课程编号(文本) 、课程名称(文本) 、教师(文本)等。4)数据流名:返回信息返回信息说明:根据用户在学生信息维护的时候所填写的信息存入了数据库之后。数据流来源:由学生信息维护界面学生输入的包含学号、姓名、性别等存入数据库的。数据流去向:学生信息维护界面。数据流组成:学号(文本) 、姓名(文本) 、班级名称(文本) 、性别(文本)等。5)数据流名:返回信息说明:根据用户在成绩管理的时候所填写的信息存入数据库后。数据流来源:由成绩管理输入的包含班级名称、教师、课程名、成绩存入数据库的。数据流去向:成绩管理的各子界面。数据流组成:班级编号(文本) ;班级名称(文本) ;教师(文本)等2.2. 对图对图 1.11.1 中所涉及的处理过程描述如下:中所涉及的处理过程描述如下:1)处理过程名:登陆输入数据流:口令号、密码输出数据流:不符合输入条件的错误信息 处理过程逻辑:用 IF 条件进行判断。2)处理过程名:班级信息维护输入数据流:班级编号、班级名称、教师等输出数据流:班级编号、班级名称等 ,其中班级编号将存在整个操作。处理过程号:班级编号,其中班级编号将存在整个操作。3)处理过程名:学生信息维护输入数据流:学号、姓名、班级编号、性别等。输出数据流:学号、姓名、班级编号、性别等。其中学号将存在整个操作。4)处理过程名:课程查询输入数据流:学号、姓名输出数据流:学号、班级名称、课程名称、上课时间节、上课时间天、上课地点、其中课程编号将存在整个操作。5)处理过程名:成绩输入输入数据流:课程编号、课程名称输出数据流:编号、学号、课程名称、成绩 、其中编号和学号将存在整个操作。(三) 系统功能结构设计系统功能结构设计 根据需求分析阶段得到的功能需求,管理员、学生和教师用户通过输入口令号和密码进下该系统后,可以进行一些学生基础信息查询(学生信息查询、班级信息查询、课程信息查询) 、学生信息维护、成绩管理(成绩查询、计算平均分)重新登陆系统、退出。 模块功能大概可以分为如下 4 个方面:这几个模块学生基础维护、成绩管理、登陆、退出。其中基础维护还要包括学生信息维护、班级信息维护、课程信息维护。成绩管理包括成绩查询、添加成绩、成绩输入等。综上所述,得到客户端功能模块图如下 2.1 所示。登录学生成绩管理系统管理员模块学生模块学生基本信息退出成绩管理成绩查询退出重新登录成绩输入成绩修改成绩添加成绩查询学生信息查询学生信息维护图 2.1 客户模块系统功能模块图三、系统设计(一)设计目标(一)设计目标通过对学生管理工作的调查和研究,要求系统设计完成后将达到以下目标:界面设计友好、美观,方便管理员的日常操作。基本信息的全面设置,数据录入方便、快捷。具有用户维护功能。最大限度地实现了易维护性和易操作性。(二)开发及运行环境(二)开发及运行环境硬件平台:CPU:P41.8GHz; 内存:256MB 以上。软件平台:操作系统:Windows2000 Server;数据库:SQL Server 2000;开发工具包:JDK Version1.5建立环境,这个过程如下:在 http:/ JDK(Java2SDK、StandardEdition、v6.0)。JDK 的安装是首先运行下载得到的 jdk-6u5-windows-i586-p.exe,然后修改系统环境变量,新建JAVA_HOME=x:jdk6.0,并在 PATH 参数中加入%JAVA_HOME%bin;,其中x:是安装 JDK 的硬盘符(c:、d:等) 。在 http:/jakarta.apache.org/处下载 Tomcat6.0。tomcat 的安装仅需将 apache-tomcat-5.5.26.zip 带目录释放到硬盘根目录下(c:、d:等) ,然后就可以在硬盘上找到 apache-tomcat-5.5.26 目录。启动则在 apache-tomcat-5.5.26/bin 目录下执行 startup.bat,就可启动 tomcat 中一个支持 JSP 网页技术的 Web 服务器。为了不与现有的 Web 服务器(例如 IIS、PWS 等)冲突,tomcat 的 Web 服务器使用了 8080 端口。在浏览器的地址栏中键入 http:/localhost:8080 或者 http:/127.0.0.1:8080 后,如果能看到 tomcat 的欢迎页就说明 JSP 实验环境已经建成,可进入下一步实验。要关闭 Web服务器则运行 shutdown.bat。(三)数据库设计(三)数据库设计 数据库连接数据库连接对动态网站来说是最为重要的部分,从 JSP 中访问数据通常是通过 Java Bean 来实现的。Java 中连接数据库的技术是 JDBC(Java Database Connectivity)。很多数据库系统带有 JDBC 驱动程序,Java 程序就通过 JDBC 驱动程序与数据库相连,执行查询、提取数据等等操作。Sun 公司还开发了 JDBC-ODBC bridge,用此技术 Java 程序就可以访问带有 ODBC 驱动程序的数据库,目前大多数数据库系统都带有 ODBC 驱动程序,所以 Java 程序能访问诸如 Oracle、Sybase、MSSQL Server 和 MS Access 等数据库。1JavaBeanJavaBeans 是基于 java 的组件模型,由属性,方法和事件 3 个部分组成。在该模型中,Javabeans 可以被修改或与其他组件结合生成新组件或完成的程序。它是一种Java 类,通过封装成为具有某种功能或者处理某个业务的对象。因此,也可以通过嵌在 JSP 页面内的 Java 代码访问 Bean 及其方法。Bean 的含义是可重复使用的 Java 组件。所谓组件就是一个由可以自行进行内部管理的一个或几个类所组成,外界了解其内部信息和运行方式的群体。使用它的对象只能通过接口来操作。Bean 实际上是根据 JavaBeans 技术标准所指定的 Bean 的命名和设计规范而编写的Java 类。Bean 并不需要继承特别的基类(base class)或事项特定的接口(Interface) 。JavaBeans1.01-A 规范定义了该组件的 5 种重要的机制:1)内省(Introspection):组件可发表其支持的操作和属性,同时也支持在其他组件中发现重复利用的对象库,例如用户权限和电子自动回复等。2)通信(Communication):生成和收集组件的消息事件3)持续(Persistence):存放组件的状态。4)属性(Properties):支持组件布局的控制,包括组件占用的空间和组件的相对位置。5)定制(Customization):开发者可控制组件所需的改变机制。6)Javabeans 可实现在设计平台被规定的操作,一般可表示为简单的图形界面,如按钮,光标和菜单等,也可以是不可见的接受并处理事件的操作,如数据库连接Bean。JSP 吸引人之处很大程度上在于它使用了 Javabeans 组件技术,但 JSP 中只支持不可见的 Javabeans。2jdbc创建一个简单的数据库连接 Bean 需要 5 个步骤:导入 JDBC 标准类库,注册数据库驱动程序,建立数据库连接,数据库操作和关闭。1)导入 JDBC 标准类库JDBC(Java DataBase Connectivity, Java 数据库连接)是一种可用于执行SQL(Structured Query Language ,结构化查询语言)语句的应用程序接口,为了将服务器从客户端接受信息存入数据库,需要使用 JDBC 标准类库,所以需要在程序的开始加入以下 import 语句:Import java.sql.*;2)注册数据库驱动程序在一个 JDBC 的驱动程序被用来建立数据库连接之前,必须向数据库驱动程序管理器注册该驱动程序。管理器的主要职责是保证所有的驱动程序对象可被 JDBC 的用户程序访问。当一个 JDBC 驱动程序被载入时,它将自动地在驱动程序管理器上注册。可以调用 Class.forName()方法载入一个 JDBC 驱动程序:String strDBDriver=sun.jdbc.odbc.JdbcOdbcDriver;Class.forName(“strDBDriver ”); Class.forName()是 Java 的 Class 类的静态方法,它使 Java 虚拟机动态的寻找,载入并连接指定的类。一个 JDBC 的驱动程序就是一个可以通过 classpath 找到一个 Java 类。这里载入的JDBC_ODBC 桥驱动程序就在 sun.jdbc.odbc 包中3)建立数据库连接载入一个正确的驱动程序后,就可以用它来建立与数据库的连接了。一个 JDBC 的数据库连接是用数据库 URL 来标记的。连接标记将告诉驱动程序管理器使用哪个驱动程序和连接哪个数据库。数据库 URL 的基本形式:jdbc::URL 的第一部分表示使用 JDBC 建立数据库连接。第 2 部分表示所使用的 JDBC驱动程序名或网络协议名。第 3 部分是数据源标记,它映射所需连接的数据库。例如数据库的数据源标记是 firm 则同 JDBC-ODBC 桥连接该数据库所用的数据库 URL 为jdbc:odbc:firm.可以通过 DriverManager 类的静态方法 getConnection()来建立一个数据库连接:String strDBUrl=jdbc:odbc:firm;conn=DriverManager.getConnection(strDBUrl,sa,);一旦建立数据库连接,就可以打开该目标数据库,并通过该连接向目标数据库SQL 指令。SQL 指令通常会执行查询,插入,更新和删除等数据库操作。要执行 SQL指令,必须通过 Connection 对象的 createStatement()方法来创建一个 STMT 对象。STMT 对象提供了许动方法来执行不同的数据库操作。可以 通过以下方式创建 STMT对象:private Connection conn=null;private Statement stmt=null;ResultSet rs=null;stmt=conn.createStatement();4)数据操作与数据库建立了连接后,接着就要进行数据操作了。数据操作包括查询,插入,更新和删除等操作。要对数据库精心操作可以使用 STMT 对象的 executeQuery()方法。executeQuery()方法接受一个 SQL 指令字符串作为参数,返回结果信息是 ResultSet 对象。具体如下:rs=stmt.executeQuery(sql);5)关闭因为数据库连接是宝贵和有限的资源,因此必须在数据库操作完毕后即使释放数据库连接。Connection 对象提供了一个简单的关闭数据库连接的方法 close()。例如:conn.close();stmt.close。利用数据库原理相关知识,对数据库设计和每个模块、每个界面的具体设计。此系统采用的数据库软件是 sqldb。以下是系统需要的六张主要数据表的结构。字段名字段类型nulldefault描述主键外键idbigint主键incrementcodevarchar(100)年级代码namevarchar(200)年级名称School_grade 年级字段名字段类型nulldefault描述主键外键idbigint主键incrementcodevarchar(100)班级代码namevarchar(200)班级名称school_gradebigint所在年级school_gradeSchool_class 班级字段名字段类型nulldefault描述主键外键idbigint主键incrementcodevarchar(50)课程编码namevarchar(200)课程名称credit_hourfloat学分passfloat及格线school_gradebigint所在学期school_gradeLesson 课程字段名字段类型nulldefault描述主键外键idbigint主键incrementusernamevarchar(200)用户名passwordvarchar(200)密码truenamevarchar(200)真实姓名sexinteger性别school_classbigint所在班级school_classStudent 学生字段名字段类型nulldefault描述主键外键idbigint主键incrementscorefloat成绩studentbigint用户studentlessonbigint课程lessonScore 成绩字段名字段类型nulldefault描述主键外键idbigint主键incrementusernamevarchar(200)用户名passwordvarchar(200)密码Admin 管理员四、系统的实现(一)学生查询成绩部分学生查询成绩部分访问 http:/localhost:8080/ST/index.html。测试用户名:test测试密码:test学生需要先登录才能进入查询程序的界面, 进入系统前要对用户和密码进行校验,即用户名和密码正确才能进入系统。并且若用户连续三次密码输入错误,则不能再次输入。输入用户 ID 后,按键,系统校验该用户是否存在.在公共方法jTuser_keyPressed()中,定义一个 String 类型变量 sqlSelect 用来生成 SQL 查询语句,再定义一个公共类 PetrieveObject 类型变量 retrieve,然后调用 retrieve 的 getObjectRow()方法,其参数为 sqlSelect,用来判断该用户是否存在。如果用户名与密码不正确,就会弹出警告信息,要求用户重新输入。登录成功后就可以看到登录学生的个人信息和相关学科的分数。(二)(二)后台管理成绩部分后台管理成绩部分访问 http:/localhost:8080/st/admin.html,进入后台管理界面。测试管理员帐号:admin测试密码:admin输入用户 ID 之后,按键,系统校验该用户是否存在。在公共方法jTuser_keyPressed()中,定义一个 String 类型变量 sqlSelect 用来生成 SQL 查询语句,再定义一个公共类 RetrieveObject 类型变量 retrieve,然后调用 retrieve 的 getObjectRow()方法,其参数为 sqlSelect,用来判断该用户是否存在。该方法的详细代码如下:Public void jTextField1_keyPressed(KeyEvent keyEvent)If(keyEvent.getKeyCode()=KeyEvent.VK_ENTER) String sqlSelect=null; Java.util.Vector vdata=null; sqlSelect=”select username from tb_user where userid=”+jTextField1.getText().trim()+”; appstu.util.RetrieveObject retrieve=new appstu.util.RetrieveObject(); vdata=retrieve.getObjectRow(sqlSelect); if (vdata.size()0) jPasswordField1.requestFocus();else Javax.swing.JOptionPane.showMessageDialog(null,”该用户不存在”,”错误” ,javax.swing.JOptionPane.ERROR_MESSAGE); jTextField1.requestFocus(); 如果用户存在,再输入对应的口令,输入的口令正确时,单击“登录”按钮,进入系统。公共方法 jTuser_keyPressed()的设计与 jTextField1_keyPressed 的设计方法相似,其关键代码如下:Public void jBlogin_actionPerformed(ActionEvent e) String sqlSelect=null; sqlSelect=”select count(*)from tb_user where userid=”+jTextField1.getText().trim() +”and pass=”+pass+”; Java.util.Vector vdata=null; appstu.util.RetrieveObject retrieve=new appstu.util.RetrieveObject(); vdata=retrieve.getObjectRow(sqlSelect); if(Integer.parseInt(String.valueOf(vdata.get(0)0) AppMain frame=new AppMain(); This.setVisible(false);else Javax.swing.JOptionPane.showMessageDialog(null,”密码错误”,”错误”,Javax.swing.JOptionPane.ERROR_MESSAGE); jPasswordField1.requestFocus(); return; 登录成功可以选择功能模块进行操作。其中包括有年级班级管理模块、课程管理模块、学生管理模块、系统管理模块。这些模块都只有管理人员才能使用。管理年级信息,年级管理模块可以添加、修改、删除各年级的 ID、年级编码及年级名称。管理班级信息,班级信息设置用来维护班级的基本情况,包括对班级信息的添加、修改和删除等操作。通过调用 Jdbcadapter,完成对班级表的相应操作。执行该模块程序,首先从数据表中检索出班级的基本信息,如果存在数据用户单击某一条数据之后可以对其进行修改、删除等操作。单击 jf_view_sysset_class.java 文件的 source 代码,编辑窗口首先导入UTIL 公共包下的相应类文件;定义一个 BOOLEAN 实例变量 INSERTFLAG,用来标志操作数据库的类型,然后定义一个私有方法 BUILDTABLE() ,用来检索班级数据。代码如下:private void buildTable() DefaultTableModel=null; String name =“班级编号”,”年级编号”,”班级名称”; String sqlstr=”select*from tb_classinfo”; Appstu.util.retrieveObject bdt=new appstu.util.RetrieveObject(); Tabemodel=bdt.getTableModel(name,sqlstr);jTable.setModel(tablemodel);jTable.setRowHeight(24); 单击“新增”按钮,用来增加一条新的数据信息。在公共方法jBadd_actionPerformed()中定义局部字符串变量 sqlgrade,用来生成年级 sql 的查询语句,然后调用公共类 RetrieveObject 的 getObjectRow()方法,其参数为 sqlgrade,将返回结果数据解析后添加到 jComboBox1 组件中。其 jBadd_actionPerformed()方法的代码如下: Public void jBadd_actionPerformed(ActionEvent e)/获得年级名称/if(jComboBox1.getItemCount()=0)Insertflag=true;RetrieveObject bdt=new RetrieveObject();String sqlgrade=”select gradeName from tb_gradeinfo”;Java.util.Vector vdata=new java.util.Vector();Vdata=bdt.getObjectRow(sqlgrade);jComboBox1.removeAllItems();for (int i=0;ivdata.size();i+) jComboBox1.addItem(vdata.get(i);ItemEvent item=new ItemEvent(jComboBox1,0,jComboBox1,jComboBox1.getSelectedIndex();jComboBox1_itemStateChanged(item);jTextField2.setText(“”);jTextField2.requestFocus();用户单击表格上的某条数据后,程序会将这条数据填写到 jPanel2 面板上的相应组件上,以方便用户进行相应的操作,在公共方法 jTable1_mouseClicked()中定义一个string 类型的局部变量 sqlStr,用来生成 sql 查询语句,然后调用公共类 RetrieveObject的 getObjectPow()方法,进行数据查询,如果找到数据则将该数据解析显示给用户,代码如下:Public void jTable1_mouseClicked(MouseEvent e) Insertflag=false; String id=null; String sqlStr=null; Int selectrow=0; Selectrow=jTable1.getSelectedRow(); If(selectrow0)return; Id=jTable1.getValueAt(selectrow,0).toSwing(); sqlStr=”SELECT c.classID,d.gradeName FROM tb_classinfo c INNER JOIN” +”tb_gradeinfo d ON c.gradeID=d.gradeID” + “where c.classID=”+id+”; Java.util.Vector vdata=null; RetrieveObject retrive=new RetrieveObject(); Vdata=retrive.getObjectRow(sqlStr); jComboBox1.removeAllItems(); jTextField1.setText(vdata.get(0).toString(); jComboBox1.addItem(vdata.get(1); jTextField2.setText(vdata.get(2).toString(); 管理课程信息,课程管理模块可增加、修改、删除学院各班级开设的课程数据,包括课程的 ID、课程代码、课程名称、课程学分、该课程的及格分数线及开设该课程的年级信息。评分模块主要是给学习某一课程的学生评分,通过选择课程的名称,可录入、修改、删除和查看学习该门课程所有学生的成绩。this.tbar = new Ext.Toolbar(选择课程:, filter, -, id: addMenu, text: 添加, iconCls : add, tooltip : 添加, disabled: true, handler: function() if (this.filter.getValue() = ) Ext.Msg.alert(提示, 请先选择课程); else var initValue = id: null, student.truename: null, student.id: null, score: 0 ; var p = new this.dataRecord(initValue); this.stopEditing(); this.store.insert(0, p); this.startEditing(0, 0); p.dirty = true; p.modified = initValue; if(this.store.modified.indexOf(p) = -1) this.store.modified.push(p); if (this.insertedRecords.indexOf(p) = -1) this.insertedRecords.push(p); .createDelegate(this) , id: deleteMenu, text: 删除, iconCls : delete, tooltip : 删除, disabled: true, handler: function() if (this.filter.getValue() = ) Ext.Msg.alert(提示, 请先选择课程); else Ext.Msg.confirm(信息, 确定要删除?, function(btn) if (btn = yes) var sm = this.getSelectionModel(); var cell = sm.getSelectedCell(); var record = this.store.getAt(cell0); if(this.store.modified.indexOf(record) != -1) this.store.modified.remove(record); / 记录删除了哪些 id var id = record.get(id); if (id = null & this.insertedRecords.indexOf(record) != -1) this.insertedRecords.remove(record); else if (id != null & this.removedRecords.indexOf(record) = -1) this.removedRecords.push(record); this.store.remove(record); , this); .createDelegate(this) , id: saveMenu, text: 提交修改, iconCls : edit, tooltip : 提交修改, disabled: true, handler: function() if (this.filter.getValue() = ) Ext.Msg.alert(提示, 请先选择课程); else var m = this.store.modified.slice(0); var data = ; Ext.each(m, function(item) data.push( id: item.get(id), studentId: item.get(student.id), score: item.get(score) ); ); var removedIds = ; Ext.each(this.removedRecords, function(item) removedIds.push(item.get(id); ); if (data.length = 0 & removedIds.length = 0) / 没有修改,不需要提交 return; 学生信息管理模块,包括学生信息的添加、修改、删除、保存修改等功能。同时学生信息中包括了学生的登陆查询界面的用户名及相应的登陆密码。单击“学生管理”/“学生”选项,进入该模块,其运行结果如下图所示。用户进入该模块后,程序首先从数据库表中检索出学生的基本信息,如果检索到学生的基本信息,那么用户在单击某一条数据之后可以对该数据进行修改、删除等操作。公共类 JdbcAdapter 是对学生表 tb_studentinfo 进行相应操作。用户单击表格中的某条数据之后,系统会将学生的信息读取到面板 jPanel1 的组件上来,以供用户进行操作,其关键代码 F_view_student.java 如下:Public void jTable1_mouseClicked(MouseEvent e)Id=jTable1.getValueAt(selectrow,0).toString();sqlStr=”select*from tb_studentinfo where stuid =”+id+”;java.util.Vetrive.getObjectRow(sqlStr);string gradeid=null,classid=null;string gradename=null,classname=null;java.util.Vector vname=null;classid=vdata.get(1).toString();gradeid=classid.substring(0,2);vname=retrive.getObjectRow(“select className from tb_classinfo where classID=+classid+”);classname=String.valueOf(vname.get(0);vname=retrive.getObjectRow(“select gradeName from tb_gradeinfo where gradeID=”+gradeid+”);gradename=String.valueOf(vname.get(0);单击“添加”按钮,进行学生的录入操作,其代码编写最大流水号的生成其中公共方法 jBdel_actionPerfromed()的关键代码 JF_view_student.java 如下:Public voidjBadd_actionPerformed(ActionEvent e) Int index=jComboBox2.getSelectedIndex();Classid=classIDindex; String sqlMax=”select max(stuid)from tb_studentinfo where classID=”+classid+”; ProduceMaxBh pm=new appstu.util.produceMaxBh(); String stuid=unll; Stuid=pm.getMax,classid); 单击“删除”按钮,删除学生信息,其中公共方法 jBdel_actionPerformed()的关键代码如下:Public viod jBdel _actionPerfromed(ActionEvente) String sqlDel=”delete tb_studentinfo where stuid=”+jTexField1.getText().trim()+”; JdbcAdapter jdbcAdapter=new JdbcAdapter();If(jdbcAdapter.DeleteObject(sqlDel) jTextField1.setText(“”);jTextField2.setText(“”);jTextField3.setText(“”);jTextField4.setText(“”);jTextField5.setText(“”);jTextField6.setText(“”);jComBox1.removeAllItems();jComBox3.removeAllItems();ActionEvent event=new ActionEvent(jBrefresh,0,null);jBrefresh_actionPerformed(event); 管理员模块,包括对管理员信息的新增、修改及删除。 五、总结随着计算机技术的普及和网络的发展,越来越多的教育单位开始重视信息化建设,利用先进的计算机和网络对学生成绩信息进行管理,提高工作效率,减少人力资源的浪费。本人结合教务管理人员对成绩信息的具体需求,开发一套学生成绩管理系统,本系统经过多次测试,能在 Visual Studio 2005 的调试环境上正常运行。基本上实现了数据管理功能,目前试运行良好。综上详细阐述了本系统的整个开发过程和实现功能,能够进行学生成绩信息录入、修改、查询、浏览、删除、统计等操作,整体界面美观大方,完成了教务人员对学生成绩管理工作的要求,适用于一系列的教育单位。本系统的应该,将会使学生和教务管理人员在第一时间内获得理想信息。 但是,由于一些技术和设备所限,本系统存在一些不足之处,有待进一步改进和完善,在开发过程中遇到了一下问题:(1) 对后台数据库中数据的日常维护,包括自动清理过时的数据;(2) 程序中错误处理和输入控制不够全面,可能导致输入无效引发错误;(3) 对补考学生的处理。参考文献参考文献:计算机网络(中级) 胡道元 清华大学出版社VB 课程设计 路慰民/龚裴秘 清华大学出版社C 程序设计(第二版) 谭浩强 清华大学出版社JSP 编程实践动态网页的引擎 何川 方兴 陈渝 齐畅 清华大学出版社深入 JSP 网络编程 雨阳隆春 等 清华大学出版社JSP 入门与提高 杨学瑜 王志军 刘同利 编著 清华大学出版社JSP 技术大全 (1-1 版) (美) Phil Hanna 机械工业出版社JSP 编程指南(第二版) 王军等译 电子工业出版社JSP 站点设计编程指南 王军等译 电子工业出版社电子政务总体设计与技术实现 国家信息研究中心著 电子工业出版社电子政务基础知识读本 汪玉凯主编 电子工业出版社精通 Java 核心技术 刘晓华等编 电子工业出版社Java 2 编程指南(SDK 1.4 版) 李昭智等译 电子工业出版社JDK1.5 类库大全 陈烨 张蓓等编著 清华大学出版社
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 图纸设计 > 任务书类


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

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


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