还剩34页未读,继续阅读
本资源只提供10页预览,全部文档请下载后查看!喜欢就下载吧,查找使用更方便
文本内容:
基于java的学生信息管理系统设计与实现基于java的学生信息管理系统设计与实现摘要利用计算机进行学生信息管理,不仅能够保证准确、无误、快速输出,而且还可以利用计算机对有关信息进行查询,检索迅速、查找方便、可靠性高、存储量大、保密性好本设计就是一个为实现信息化管理而开发的信息管理系统,能够进行信息存储、查询、修改等能功该系统由六个模块构成,包括学生管理系统的主界面模块、学生信息管理模块、课程信息管理模块、成绩信息管理模块、信息查询模块和数据库操作模块通过这些模块的有机结合,能方便的对学生信息进行综合管理,从而实现了信息化管理的目的由于本人的能力有限,设计过程中难免有不足之处,设计中的存在问题本人将在日后进一步修改,以便让程序的设计更加完善 关键词oracle; 异常处理;关系模型目录TOC\o1-3\h\z\uHYPERLINK\l_Toc2962896641引言1HYPERLINK\l_Toc
2962896651.1背景及意义1HYPERLINK\l_Toc
2962896661.2实验技术选择1HYPERLINK\l_Toc
2962896671.3课题实现技术的简要说明5HYPERLINK\l_Toc
2962896681.4可行性分析6HYPERLINK\l_Toc2962896692系统需求分析6HYPERLINK\l_Toc2962896703学生信息管理系统设计7HYPERLINK\l_Toc
2962896713.1数据模型分析与设计8HYPERLINK\l_Toc
2962896723.2结构设计与结构功能图10HYPERLINK\l_Toc
2962896733.
2.1结构设计10HYPERLINK\l_Toc
2962896743.
2.2功能结构图10HYPERLINK\l_Toc2962896754系统实现12HYPERLINK\l_Toc2962896765系统调试与测试17HYPERLINK\l_Toc
2962896775.1系统功能测试17HYPERLINK\l_Toc
2962896785.2系统调试常见错误17HYPERLINK\l_Toc2962896796实验小结19HYPERLINK\l_Toc296289680参考文献19 1引言
1.1背景及意义学生信息管理系统是一个教育单位不可缺少的部分一个功能齐全、简单易用的信息管理系统不但能有效地减轻学校相关工作人员的工作负担,它的内容对于学校的决策者和管理者来说都至关重要所以学生信息管理系统应该能够为用户提供充足的信息和快捷的查询手段但一直以来人们使用传统人工的方式管理文件档案、统计和查询数据,这种管理方式存在着许多缺点,如效率低、保密性差、人工的大量浪费;另外时间一长,将产生大量的文件和数据,这对于查找、更新和维护都带来了不少困难随着科学技术的不断提高,计算机科学日渐成熟其强大的功能已为人们深刻认识,它已进入人类社会的各个领域并发挥着越来越重要的作用作为计算机应用的一部分,使用计算机对学校的各类信息进行管理,具有手工管理无法比拟的优点例如检索迅速、查询方便、效率高、可靠性好、存储量大、保密性好、寿命长、成本低等利用计算机进行学生信息管理,不仅能够保证准确、无误、快速输出,而且还可以利用计算机对有关信息进行查询,检索迅速、查找方便、可靠性高、存储量大、保密性好要科学地实现信息化管理,开发一个适合学校的,能够进行信息存储、查询、修改等功能的信息管理系统是十分重要的这些优点能够极大地提高学校信息管理的效率,也是一个单位科学化、正规化管理,与世界接轨的重要条件本系统是将现代化的计算机技术和传统的教学、教务工作相结合,按照学院的工作流程设计完成的通过一个简化的学生信息管理系统,使学生信息管理工作系统化、规范化、自动化,从而达到提高学生信息管理效率的目的本课题就是针对便于学生信息管理的问题而设计的一个管理系统
1.2实验技术选择本课题设计主要运用的技术有两个java项目开发和oracle对数据库的操作这里主要介绍本课题为什么选用这两个开发技术⑴首先了解一下Java语言特点Java是一种跨平台,适合于分布式计算环境的面向对象编程语言具体来说,它具有如下特性简单性、面向对象、分布式、解释型、可靠、安全、平台无关、可移植、高性能、多线程、动态性等下面我们将重点介绍Java语言的面向对象、平台无关、分布式、多线程、可靠和安全等特性
①面向对象面向对象其实是现实世界模型的自然延伸现实世界中任何实体都可以看作是对象对象之间通过消息相互作用另外,现实世界中任何实体都可归属于某类事物,任何对象都是某一类事物的实例如果说传统的过程式编程语言是以过程为中心以算法为驱动的话,面向对象的编程语言则是以对象为中心以消息为驱动用公式表示,过程式编程语言为程序=算法+数据;面向对象编程语言为程序=对象+消息所有面向对象编程语言都支持三个概念封装、多态性和继承,Java也不例外现实世界中的对象均有属性和行为,映射到计算机程序上,属性则表示对象的数据,行为表示对象的方法(其作用是处理数据或同外界交互)所谓封装,就是用一个自主式框架把对象的数据和方法联在一起形成一个整体可以说,对象是支持封装的手段,是封装的基本单位Java语言的封装性较强,因为Java无全程变量,无主函数,在Java中绝大部分成员是对象,只有简单的数字类型、字符类型和布尔类型除外而对于这些类型,Java也提供了相应的对象类型以便与其他对象交互操作多态性就是多种表现形式,具体来说,可以用“一个对外接口,多个内在实现方法”表示举一个例子,计算机中的堆栈可以存储各种格式的数据,包括整型,浮点或字符不管存储的是何种数据,堆栈的算法实现是一样的针对不同的数据类型,编程人员不必手工选择,只需使用统一接口名,系统可自动选择运算符重载(operatoroverload一直被认为是一种优秀的多态机制体现,但由于考虑到它会使程序变得难以理解,所以Java最后还是把它取消了继承是指一个对象直接使用另一对象的属性和方法事实上,我们遇到的很多实体都有继承的含义例如,若把汽车看成一个实体,它可以分成多个子实体,如卡车、公共汽车等这些子实体都具有汽车的特性,因此,汽车是它们的“父亲”,而这些子实体则是汽车的“孩子”Java提供给用户一系列类(class),Java的类有层次结构,子类可以继承父类的属性和方法与另外一些面向对象编程语言不同,Java只支持单一继承
②平台无关性Java是平台无关的语言是指用Java写的应用程序不用修改就可在不同的软硬件平台上运行平台无关有两种源代码级和目标代码级C和C++具有一定程度的源代码级平台无关,表明用C或C++写的应用程序不用修改只需重新编译就可以在不同平台上运行Java主要靠Java虚拟机(JVM)在目标码级实现平台无关性JVM是一种抽象机器,它附着在具体操作系统之上,本身具有一套虚机器指令,并有自己的栈、寄存器组等但JVM通常是在软件上而不是在硬件上实现(目前,SUN系统公司已经设计实现了Java芯片,主要使用在网络计算机NC上另外,Java芯片的出现也会使Java更容易嵌入到家用电器中)JVM是Java平台无关的基础,在JVM上,有一个Java解释器用来解释Java编译器编译后的程序Java编程人员在编写完程序后,通过Java编译器将Java源程序编译为JVM的字节代码任何一台机器只要配备了Java解释器,就可以运行这个程序,而不管这种字节码是在何种平台上生成的另外,Java采用的是基于IEEE标准的数据类型通过JVM保证数据类型的一致性,也确保了Java的平台无关性Java的平台无关性具有深远意义首先,它使得编程人员所梦寐以求的事情(开发一次软件在任意平台上运行)变成事实,这将大大加快和促进软件产品的开发其次Java的平台无关性正好迎合了“网络计算机”思想如果大量常用的应用软件(如字处理软件等)都用Java重新编写,并且放在某个Internet服务器上,那么具有NC的用户将不需要占用大量空间安装软件,他们只需要一个Java解释器,每当需要使用某种应用软件时,下载该软件的字节代码即可,运行结果也可以发回服务器目前,已有数家公司开始使用这种新型的计算模式构筑自己的企业信息系统
③分布式分布式包括数据分布和操作分布数据分布是指数据可以分散在网络的不同主机上,操作分布是指把一个计算分散在不同主机上处理Java支持WWW客户机/服务器计算模式,因此,它支持这两种分布性对于前者,Java提供了一个叫作URL的对象,利用这个对象,你可以打开并访问具有相同URL地址上的对象,访问方式与访问本地文件系统相同对于后者,Java的applet小程序可以从服务器下载到客户端,即部分计算在客户端进行,提高系统执行效率Java提供了一整套网络类库,开发人员可以利用类库进行网络程序设计,方便得实现Java的分布式特性
④可靠性和安全性Java最初设计目的是应用于电子类消费产品,因此要求较高的可靠性Java虽然源于C++,但它消除了许多C++不可靠因素,可以防止许多编程错误首先,Java是强类型的语言,要求显式的方法声明,这保证了编译器可以发现方法调用错误,保证程序更加可靠;其次,Java不支持指针,这杜绝了内存的非法访问;第三,Java的自动单元收集防止了内存丢失等动态内存分配导致的问题;第四,Java解释器运行时实施检查,可以发现数组和字符串访问的越界,最后,Java提供了异常处理机制,程序员可以把一组错误代码放在一个地方,这样可以简化错误处理任务便于恢复由于Java主要用于网络应用程序开发,因此对安全性有较高的要求如果没有安全保证,用户从网络下载程序执行就非常危险Java通过自己的安全机制防止了病毒程序的产生和下载程序对本地系统的威胁破坏当Java字节码进入解释器时,首先必须经过字节码校验器的检查,然后,Java解释器将决定程序中类的内存布局,随后,类装载器负责把来自网络的类装载到单独的内存区域,避免应用程序之间相互干扰破坏最后,客户端用户还可以限制从网络上装载的类只能访问某些文件系统上述几种机制结合起来,使得Java成为安全的编程语言
⑤多线程线程是操作系统的一种新概念,它又被称作轻量进程,是比传统进程更小的可并发执行的单位C和C++采用单线程体系结构,而Java却提供了多线程支持Java在两方面支持多线程一方面,Java环境本身就是多线程的若干个系统线程运行负责必要的无用单元回收,系统维护等系统级操作;另一方面,Java语言内置多线程控制,可以大大简化多线程应用程序开发Java提供了一个类Thread,由它负责启动运行,终止线程,并可检查线程状态Java的线程还包括一组同步原语这些原语负责对线程实行并发控制利用Java的多线程编程接口,开发人员可以方便得写出支持多线程的应用程序,提高程序执行效率必须注意地是,Java的多线程支持在一定程度上受运行时支持平台的限制例如,如果操作系统本身不支持多线程,Java的多线程特性可能就表现不出来⑵oracle数据库的特点●无范式要求,可根据实际系统需求构造数据库●采用标准的SQL结构化查询语言●具有丰富的开发工具,覆盖开发周期的各阶段●支持大型数据库,数据类型支持数字、字符、大至4GB的二进制数据,为数据库的面向存储提供数据支持●具有第四代语言的开发工具(SQL*formS、SQL*REPORTS、SQL*MENU等)●具有字符界面和图形界面,易于开发●通过SQL*DBA控制用户权限,提供数据保护功能,监控数据库的运行状态,调整数据缓冲区的大小●分布优化查询功能●具有数据透明、网络透明,支持异种网络、异构数据库系统并行处理采用动态数据分片技术●支持客户机/服务器体系结构及混合的体系结构(集中式、分布式、客户机/服务器)●实现了两阶段提交、多线索查询手段●支持多种系统平台(HPUX、SUNOS、OSF/
1、VMS、WINDOWS、WINDOWS/NT、OS/2)●数据安全保护措施没有读锁,采取快照SNAP方式完全消除了分布读写冲突自动检测死锁和冲突并解决●数据安全级别为C2级(最高级)●数据库内模支持多字节码制,支持多种语言文字编码●具有面向制造系统的管理信息系统和财务系统应用系统综上所述,选择java作为开发语言,oracle作为数据库开发工具是个不错的选择java语言的面向对象、平台无关、分布式、多线程、可靠和安全等特性,使得开发出来的项目具有健壮性、可维护性、可移植性等特点Oracle是目前最具权威的数据库产品,它具有的兼容性、可移植性、可联结性、高生产率和开放性的特点,使它成为当今众多的程序开发人员首选的数据库开发工具所以本课题选择java和oracle作为开发技术是为今后开发更复杂的项目打下基础,以免到时候遇到相关的技术问题而不知所措
1.3课题实现技术的简要说明本课题主要运用了java图形编程和oracle数据库的操作Java图形编程给用户提供了一个直观、易于与用户进行交互的图形界面在图形编程中,运用了大量的java.swing包中的类,之所以选择swing包中的类而不选java.awt包中的类,主要是swing包中的类能给用户提供更好的观感oracle数据库的操作这部分内容分成三部分来实现首先,编写对数据库操作的类,包括连接数据库、执行sql语句、关闭数据库连接等其次,编写一个用于对学生信息进行数据库操作的类,包括学生信息的增加、修改、删除和查询等最后,编写一个用于对课程相关信息进行数据库操作的类,包括对课程信息的增加、修改、删除、查询等等通过结合图形编程和数据库编程,从而基本上实现了学生信息管理的基本功能,由于本人技术上的不足,难免有些地方需要改进,这些存在的问题都将成为本人前进的动力,并在日后更加完善本课题的设计
1.4可行性分析系统的性质为管理软件,因而数据库的设计与操纵是系统设计的核心这里从两方面分析技术上的可行性首先,对于java编程部分,java课已经开过因此在课题设计中,对java图形编程方面的问题都能迎韧而解其次,对于数据库的有关知识,本人运用了大量的时间对相关书籍的阅读以及上机实验,基本上掌握了运用oracle数据库技术,具备一定的系统分析与设计能力,熟悉数据库的设计与操纵;因而该系统的实现在技术上是可行的2系统需求分析本课题根据学生信息管理综合分析,便出于方便管理考虑,将学生信息管理系统的功能总结起来,共需要实现以下几个方面功能
①管理学生信息管理所有学生的基本信息,对学生信息的操作包括添加、修改、删除等;可以根据各种条件查询出需要的信息,比如修改,可以通过学生学号查询出学生的基本信息,然后通过对需要修改项进行修改并保存修改后的结果存入数据库的学生表中
②管理课程信息管理所有课程的基本信息,包括对课程信息的添加、修改、删除等操作;可以根据各种条件查询出需要的信息,并对相应的信息进行操作比如修改和删除,可以通过学生的学号查询出学生的相应课程信息,对相应的课程进行修改、删除操作
③学生选课与成绩根据学生的学号进行选课,登记所选课程的成绩;可以根据学号查询出选课信息与成绩通过以上功能的设计与实现,并实现学生信息管理系统的基本功能3学生信息管理系统设计
3.1数据模型分析与设计数据库模型描述了在数据库中结构化和操纵数据的方法,模型的结构部分规定了数据如何被描述(例如树、表等);模型的操纵部分规定了数据的添加、删除、显示、维护、打印、查找、选择、排序和更新等操作数据库模型的分类分层模型、关系模型、网络模型和对象模型本课题选择的关系模型,关系模型是目前最重要的一种数据模型关系数据库系统采用关系模型作为数据的组织方式关系数据模型具有下列优点●关系模型与非关系模型不同,它是建立在严格的数学概念的基础上的●关系模型的概念单一无论实体还是实体之间的联系都用关系表示对数据的检索结构也是关系(即表)所以其数据结构简单、清晰,拥护易懂易用●关系模型的存取路径对用户透明,从而具有更高的数据独立性、更好的安全保密性,也简化了程序员的工作和数据库开发建立的工作所以,关系数据模型诞生以后发展迅速,深受拥护的喜爱,这也是本课题选取关系数据模型的原因当然,关系数据模型也有缺点,其中最主要的缺点是,由于存取路件对用户透明,查询效率往往不如非关系数据模型因此为了提高性能,必须对用户的查询请求进行优化,增加了开发数据库管理系统的难度本课题的关系数据模型的数据结构可分为三个表来表示学生信息表(Student)、课程信息表(Course)、学生选课表(SC);学生信息表用于记录学生的基本信息,如表3-1;课程信息表用于记录课程的基本信息,如表3-2;学生选课表如下表3-3这三个表对应的E-R图分别是图
3.1学生信息E-R图;图
3.2课程信息E-R图;图
3.3学生选课E-R图;如下图表3-1学生信息表(Student)名称数据类型主键非空学号Number10YesYes学生姓名Varchar2NoYes性别Char2NoNo年龄Char2NoNo专业Varchar2NoNo学院Char8NoNo表3-2课程信息表(Course)名称数据类型主键非空课程编号Char4YesYes课程名称Varchar2NoYes授课教师Varchar2NoNo上课地点Varchar2NoNo课程类别Char1NoNo表3-3学生选课表(SC)名称数据类型主键非空学号Char10YesYes课程编号Char4YesYes成绩Number41NoNo
3.2结构设计与结构功能图
3.
2.1结构设计根据对系统进行需求分析,本系统将分为4个模块●学生管理管理学生基本信息,包括个人信息的添加、修改、删除以及选课信息的添加●课程管理管理课程的基本信息,包括课程信息的添加、修改和删除●成绩管理管理学生选课的成绩信息,包括成绩的登记与修改●信息查询查询已经登记的信息,包括学生的基本信息、课程的基本信息与成绩信息
3.
2.2功能结构图学生管理系统功能结构如图
3.4所示4系统实现该系统由6个模块构成,包括学生管理系统主界面模块、学生信息管理模块、课程信息管理模块、成绩信息管理模块、信息查询模块和数据操作模块下面分别加以叙述
①学生管理系统主界面模块学生管理系统主界面模块包括StuMS.java和StuMain.java两个文件StuMS是学生管理系统的主运行类,其中有运行整个程序的main方法,该文件生成了StuMain类的一个实例,从而生成了学生管理系统的界面,如图
4.1所示StuMain类继承自JFrame类,实现了ActionListener接口,他有一个不带参数的构造方法StuMain用来生成StuMain的实例StuMain类将所有功能集中到菜单栏中,并通过调用其他模块来实现学生管理系统的各个功能图
4.1学生管理系统主界面
②学生信息管理模块学生信息管理模块主要由StuInfo.java、AddStuInfo.java、EdiStuInfo.java、DelStuInfo.java、SelectCourse.java和StuInfoSearchSnum.java共计6个文件组成,其构成关系如图
4.2所示学生信息管理模块的6个文件组成了主界面中的“学生管理”菜单的内容,其中包括增加、修改、删除和学生选课功能,如图
4.3所示图
4.3学生信息管理模块的运行界面
③课程信息管理模块课程信息管理模块主要由CourseInfo.java、AddCourseInfo.java、EditCourseInfo.java、DelCourseInfo.java、CourseInfoSearchCnum.java这5个文件组成,其构成关系如图
4.4所示课程信息管理模块中的5个类文件组成了主界面中“课程管理”菜单的内容,其中包括增加、修改和删除功能,如图
4.5所示图
4.5课程信息管理模块运行界面
④成绩信息管理模块成绩信息管理模块主要由GradeInfo.java、AddGradeInfo.java、EditGradeInfo.java这3个文件组成,其构成关系如图
4.6所示成绩信息管理模块中的3个类文件组成了主界面中的“成绩管理”菜单的内容,其中包括增加和修改功能,如图
4.7所示图
4.7成绩信息管理模块的运行界面
⑤信息查询模块信息查询模块主要包括学生查询、课程查询和成绩查询3个部分信息查询的运行主截面如图
4.8所示图
4.8学生信息查询模块的运行界面学生查询由StuSearchSnum.java、StuSearchSsex.java、StuSearchScollege.java、StuSearchSmajor.java和ResultStudent.java这6个文件组成,主要实现功能包括按学号查询、按学生姓名查询、按性别查询、按学院查询与按专业查询5系统调试与测试
5.1系统功能测试功能测试主要是测试程序模块是否实现了设计中所要求的功能功能测试中需要注意的有1查询功能中,有按单一查询条件进行查询的,也有按多个查询条件组合查询的这里要注意的多个查询条件之间的关系还有一些常识性的问题,比如按月查询,闰月中二月的天数2录入功能中,需要注意的是前台设置的数值长度是否大于后台数值长度,以及前台和后台的数据结构是否相符,很多时候录入功能无法实现是由于这些原因还有就是必须录入的字段的设置时候有误3测试删除功能中需要注意的是单击删除按钮后,一般会出现提示信息,询问是否确定删除通常情况下,我们单击确认按钮查看信息是否被删除掉了,而忽略了单击取消按钮后程序的反应这时有可能的是没有删除,还有一种可能是即便单击了取消按钮,也一样删除了数据另外,在删除多条记录的时候,要注意连续选中的几条记录是否真正都被删除掉了,即如果再按照这种查询方式查询,时候还能查询出来有的时候需要在数据库中设立一个标志位,而不是真正的物理删除所以在下一次查询中,可能还会被查询出来,这主要是因为在查询条件中没有将标志考虑在内4关于修改功能的测试主要是看修改确认后是否数据真正已被修改了这是最基本的功能,需要注意的是看是否能把不应该修改的数据也修改成功了
5.2系统调试常见错误
1.NullPointerException异常一般是对一个为NULL值的变量进行操作引起的为避免这种异常,最好在对变量操作之前检查,看它是否为NULL值
2.SQLException异常一般是由于SQL语句不正确引起的为避免这种异常,最好在使用SQL语句的程序中捕获此SQL异常
3.NumberFormatException异常这是由于数字的格式错误而出现的例外为了避免出现此类错误,一般必须保证数据格式输入正确
4.数据库连接垃圾回收在实际的开发应用中,通常出现某一个对象未能关闭的情况,为了防止这种情况的发生,可以在有关对数据库操作的Java类文件中增加自动回收函数,在JVM自动地回收对象时,取出使用的连接对象,判断是否关闭,如果没有关闭则关掉代码如下所示protectedvoidfinalize{try{IfgetConn!=null!getConn.isClosed{rs.cloes;stm.close;conn.close;}}catchSQLExceptione{}}6实验小结经过这次课题的设计并实现,尽管会遇到很多难题,但是让我更加受益的是在这次课题中得到的经验、心得和锻炼我发现做实验的过程其实就是个不断的解决问题的过程,从中也感觉到实验成功的快乐,一个人永远有学不玩的知识,就算是实验中的知识点都学了,但在实际的应用过程中仍然会遇到不少问题,遇到问题时要做到两点一个是“查”,一个是“问”不懂的地方就得要自己找答案,可以从书本、网络中查找解决的答案;再一个就是问周边的同学这次课程的设计给我所学的知识做了一个总结,为我深入学习编程做了铺垫在本课题中存在的不足之处是在所难免的,本人将在日后加于改进参考文献
[1]王克宏、郝建文.Java技术教程[M].北京清华大学出版社,2002年9月.
[2]蔡敏、徐慧慧、黄炳强.UML基础与Rose建模教程[M].北京人民邮电出版社,2006年5月.
[3]萨师煊、王珊.数据库系统概论(第三版)[M].北京高等教育出版社,2005年12月.
[4] 齐治昌、谭庆平、宁洪. 软件工程(第二版)[M]. 北京高等教育出版社,2004年,3月.
[5] 周竞涛、赵寒. Eclipse完全手册 [M]. 北京电子工业出版社,2006年,8月.
[6] Cay S.Horstmann、Gary Cornll. 叶乃文 等译. Java核心技术 [M] 北京机械工业出版社,2006年5月.
[7] 蒙祖强、龚涛. Oracle 10g 数据库Java开发. 北京中国水利水电出版社,2005年6月.附录代码//AddStuInfo.javapackagecom.main;importjava.awt.event.ActionEvent;importjava.awt.event.ActionListener;importjava.sql.Connection;importjavax.swing.JButton;importjavax.swing.JComboBox;importjavax.swing.JFrame;importjavax.swing.JLabel;importjavax.swing.JTextField;importjavax.swing.JOptionPane;importcom.bean.Student;importcom.dao.StudentDao;importcom.db.DB;importcom.main.DelteStudent.delAction;publicclassAddStuInfoextendsJFrame{StudentDaostudao=newStudentDao;DBdb=newDB;Connectionconn=db.getConnection;JTextFieldsnoText=null;JTextFieldsnameText=null;JComboBoxsexcom=null;JTextFieldageText=null;JComboBoxclasscom=null;JComboBoxdepartcom=null;publicvoidinit{//窗体设计this.setLayoutnull;this.setTitle学生信息管理系统;this.setSize500400;JLabeltitle=newJLabel学生信息维护模块---录入数据;title.setBounds1802020030;this.addtitle;JLabelsnoLabel=newJLabel学号;snoText=newJTextField;snoLabel.setBounds20604025;snoText.setBounds606012025;this.addsnoLabel;this.addsnoText;JLabelsnameLabel=newJLabel姓名;snameText=newJTextField;snameLabel.setBounds220604025;snameText.setBounds2606012025;this.addsnameLabel;this.addsnameText;JLabelsexlabel=newJLabel性别;String[]sex={男女};sexcom=newJComboBoxsex;sexlabel.setBounds20904025;sexcom.setBounds609012025;this.addsexlabel;this.addsexcom;JLabelageLabel=newJLabel年龄;ageText=newJTextField;ageLabel.setBounds220904025;ageText.setBounds2609012025;this.addageLabel;this.addageText;JLabelclasslabel=newJLabel班级;String[]classes={信息081信息082物流081};classcom=newJComboBoxclasses;classlabel.setBounds201204025;classcom.setBounds6012012025;this.addclasslabel;this.addclasscom;JLabeldepartlabel=newJLabel学院;String[]depart={造纸理学院机电学院};departcom=newJComboBoxdepart;departlabel.setBounds2201204025;departcom.setBounds26012012025;this.adddepartlabel;this.adddepartcom;//录入数据JButtonaddbtn=newJButton录入;addbtn.setBounds1501806030;addbtn.addActionListenernewaddAction;this.addaddbtn;//返回JButtonbackbtn=newJButton返回;backbtn.setBounds2301806030;backbtn.addActionListenernewBackAction;this.addbackbtn;this.setLocationRelativeTonull;//使窗体居中this.setResizablefalse;//固定窗体大小this.setVisibletrue;//设置窗体可见//this.setDefaultCloseOperationJFrame.EXIT_ON_CLOSE;//窗体关闭时,程序结束}//获取文本框或选择框的值publicStudentgetStudent{Studentstu=newStudent;Stringsno=snoText.getText;//获取输入的学号Stringsname=snameText.getText;//获取姓名Stringsex=Stringsexcom.getSelectedItem;//获取性别intage=Integer.parseIntageText.getText.trim;//获取年龄StringclassName=Stringclasscom.getSelectedItem;//获取班级Stringdepart=Stringdepartcom.getSelectedItem;//获取学院//封装信息stu.setSnosno;stu.setNamesname;stu.setSexsex;stu.setAgeage;stu.setClassNameclassName;stu.setDepartdepart;returnstu;}publicstaticvoidmainString[]args{AddStudentaddstu=newAddStudent;addstu.init;}//录入的监听器classaddActionimplementsActionListener{publicvoidactionPerformedActionEvente{Studentstu=getStudent;booleanb=studao.savestuconn;ifb{JOptionPane.showMessageDialognull数据录入成功!;}else{JOptionPane.showMessageDialognull学号已存在数据录入失败!;}}}classBackActionimplementsActionListener{publicvoidactionPerformedActionEvente{MainFramem=newMainFrame;m.init;}}}//DelStuInfo.javapackagecom.main;importjava.awt.event.ActionEvent;importjava.awt.event.ActionListener;importjava.sql.Connection;importjava.sql.SQLException;importjava.util.Vector;importjavax.swing.JButton;importjavax.swing.JComboBox;importjavax.swing.JFrame;importjavax.swing.JLabel;importjavax.swing.JOptionPane;importcom.bean.Student;importcom.dao.StudentDao;importcom.db.DB;importcom.main.AddStudent.BackAction;//删除学生信息publicclassDelStuInfoextendsJFrame{StudentDaostudao=newStudentDao;DBdb=newDB;Connectionconn=db.getConnection;JComboBoxsnocom=null;publicvoidinit{//窗体设计this.setLayoutnull;this.setTitle学生信息管理系统;this.setSize500400;JLabeltitle=newJLabel学生信息维护模块---删除数据;title.setBounds1802020030;this.addtitle;//选择学号JLabelsnoLabel=newJLabel请选择要删除学生信息的学号;snoLabel.setBounds206020025;this.addsnoLabel;try{Vectorvec=studao.getSno;snocom=newJComboBoxvec;//将数据库里的学号信息装入下拉框中snocom.setBounds309015025;}catchSQLExceptione{e.printStackTrace;}this.addsnocom;//删除数据JButtondelbtn=newJButton删除;delbtn.setBounds1001806030;delbtn.addActionListenernewdelAction;this.adddelbtn;//返回JButtonbackbtn=newJButton返回;backbtn.setBounds1801806030;backbtn.addActionListenernewBackAction;this.addbackbtn;this.setLocationRelativeTonull;//使窗体居中this.setResizablefalse;//固定窗体大小this.setVisibletrue;//设置窗体可见//this.setDefaultCloseOperationJFrame.EXIT_ON_CLOSE;//窗体关闭时,程序结束}publicstaticvoidmainString[]args{DelteStudentdelstu=newDelteStudent;delstu.init;}//删除的监听器classdelActionimplementsActionListener{publicvoidactionPerformedActionEvente{Stringdelsno=Stringsnocom.getSelectedItem;booleanb=studao.deletedelsnoconn;ifb{JOptionPane.showMessageDialognull删除录入成功!;}else{JOptionPane.showMessageDialognull删除录入失败!;}}}classBackActionimplementsActionListener{publicvoidactionPerformedActionEvente{MainFramem=newMainFrame;m.init;}}}packagecom.main;importjava.awt.event.ActionEvent;importjava.awt.event.ActionListener;importjava.sql.Connection;importjava.sql.SQLException;importjava.util.Vector;importjavax.swing.JButton;importjavax.swing.JComboBox;importjavax.swing.JFrame;importjavax.swing.JLabel;importjavax.swing.JTextField;importjavax.swing.JOptionPane;importcom.bean.Student;importcom.dao.StudentDao;importcom.db.DB;importcom.main.AddStudent.BackAction;importcom.main.DelteStudent.delAction;publicclassEditFrameextendsJFrame{StudentDaostudao=newStudentDao;DBdb=newDB;Connectionconn=db.getConnection;JTextFieldsnameText=null;JComboBoxsexcom=null;JTextFieldageText=null;JComboBoxclasscom=null;JComboBoxdepartcom=null;JComboBoxsnocom=null;publicvoidinit{//窗体设计this.setLayoutnull;this.setTitle学生信息管理系统;this.setSize500400;JLabeltitle=newJLabel学生信息维护模块---修改数据;title.setBounds1802020030;this.addtitle;JLabelsnoLabel=newJLabel学号;snoLabel.setBounds20604025;this.addsnoLabel;try{Vectorvec=studao.getSno;snocom=newJComboBoxvec;//将数据库里的学号信息装入下拉框中snocom.setBounds606012025;}catchSQLExceptione{e.printStackTrace;}this.addsnocom;JLabelsnameLabel=newJLabel姓名;snameText=newJTextField;snameLabel.setBounds220604025;snameText.setBounds2606012025;this.addsnameLabel;this.addsnameText;JLabelsexlabel=newJLabel性别;String[]sex={男女};sexcom=newJComboBoxsex;sexlabel.setBounds20904025;sexcom.setBounds609012025;this.addsexlabel;this.addsexcom;JLabelageLabel=newJLabel年龄;ageText=newJTextField;ageLabel.setBounds220904025;ageText.setBounds2609012025;this.addageLabel;this.addageText;JLabelclasslabel=newJLabel班级;String[]classes={信息081信息082物流081};classcom=newJComboBoxclasses;classlabel.setBounds201204025;classcom.setBounds6012012025;this.addclasslabel;this.addclasscom;JLabeldepartlabel=newJLabel学院;String[]depart={造纸理学院机电学院};departcom=newJComboBoxdepart;departlabel.setBounds2201204025;departcom.setBounds26012012025;this.adddepartlabel;this.adddepartcom;//修改JButtoneditbtn=newJButton修改;editbtn.setBounds1501806030;editbtn.addActionListenerneweditAction;this.addeditbtn;//返回JButtonbackbtn=newJButton返回;backbtn.setBounds2201806030;backbtn.addActionListenernewBackAction;this.addbackbtn;this.setLocationRelativeTonull;//使窗体居中this.setResizablefalse;//固定窗体大小this.setVisibletrue;//设置窗体可见//this.setDefaultCloseOperationJFrame.EXIT_ON_CLOSE;//窗体关闭时,程序结束}//获取文本框或选择框的值publicStudentgetStudent{Studentstu=newStudent;Stringsno=Stringsnocom.getSelectedItem;//获取输入的学号Stringsname=snameText.getText;//获取姓名Stringsex=Stringsexcom.getSelectedItem;//获取性别intage=Integer.parseIntageText.getText.trim;//获取年龄StringclassName=Stringclasscom.getSelectedItem;//获取班级Stringdepart=Stringdepartcom.getSelectedItem;//获取学院//封装信息stu.setSnosno;stu.setNamesname;stu.setSexsex;stu.setAgeage;stu.setClassNameclassName;stu.setDepartdepart;returnstu;}publicstaticvoidmainString[]args{EditFrameeditstu=newEditFrame;editstu.init;}//修改监听器classeditActionimplementsActionListener{publicvoidactionPerformedActionEvente{Studentstu=getStudent;booleanb=studao.editstu.getSnostu.getNamestu.getSexstu.getAgestu.getClassNamestu.getDepartconn;ifb{JOptionPane.showMessageDialognull数据修改成功!;}else{JOptionPane.showMessageDialognull数据修改失败!;}}}classBackActionimplementsActionListener{publicvoidactionPerformedActionEvente{MainFramem=newMainFrame;m.init;}}} 学生学号学生姓名性别专业年级出生图
3.1学生信息E-R图课程课程编号上课地点课程名称授课教师课程类别图
3.2课程信息E-R图选课表学号课程编号成绩图
3.3学生选课E-R图学生管理系统学生管理课程管理成绩管理信息查询添加增加删除学生查询增加课程查询修改修改修改删除学生选课成绩查询按姓名查询按学号查询按性别查询按专业查询按学院查询按课程名称查询查询所有科目成绩按授课老师查询图
3.4学生管理系统功能结构图学生信息超类StuInfo.java增加学生信息AddStuInfo.java修改学生信息EdiStuInfo.java删除学生信息DelStuInfo.java学生选课SelectCourse.java按学号查询StuInfoSearchSnum.java按学号查询StuInfoSearchSnum.java图
4.2学生信息管理模块功能结构图课程信息超类CourseInfo.java增加课程信息AddCourseInfo.java修改课程信息EditCourseInfo.java删除课程信息DelCourseInfo.java按课程号查询CourseInfoSearchCnum.java按课程号查询CourseInfoSearchCnum.java图
4.4课程信息管理模块功能结构图成绩管理超类GradeInfo.java增加成绩信息AddGradeInfo.java修改成绩信息EditGradeInfo.java图
4.6成绩信息管理模块功能结构图。