1、基于 java 的学生信息管理系统设计与实现基于 java 的学生信息管理系统设计与实现摘要:利用计算机进行学生信息管理,不仅能够保证准确、无误、快速输出,而且还可以利用计算机对有关信息进行查询,检索迅速、查找方便、可靠性高、存储量大、保密性好。本设计就是一个为实现信息化管理而开发的信息管理系统,能够进行信息存储、查询、修改等能功。该系统由六个模块构成,包括学生管理系统的主界面模块、学生信息管理模块、课程信息管理模块、成绩信息管理模块、信息查询模块和数据库操作模块。通过这些模块的有机结合,能方便的对学生信息进行综合管理,从而实现了信息化管理的目的。由于本人的能力有限,设计过程中难免有不足之处,
2、设计中的存在问题本人将在日后进一步修改,以便让程序的设计更加完善。 关键词:oracle; 异常处理;关系模型目录1 引 言 .11.1 背景及意义 .11.2 实验技术选择 11.3 课题实现技术的简要说明 51.4 可行性分析 .62 系统需求分析 63 学生信息管理系统设计 .73.1 数据模型分析与设计 .83.2 结构设计与结构功能图 .103.2.1 结构设计 103.2.2 功能结构图 104 系统实现 125 系统调试与测试 175.1 系统功能测试 175.2 系统调试常见错误 176 实验小结 19参考文献 191 引 言1.1 背景及意义学生信息管理系统是一个教育单位不可
3、缺少的部分。一个功能齐全、简单易用的信息管理系统不但能有效地减轻学校相关工作人员的工作负担,它的内容对于学校的决策者和管理者来说都至关重要。所以学生信息管理系统应该能够为用户提供充足的信息和快捷的查询手段。但一直以来人们使用传统人工的方式管理文件档案、统计和查询数据,这种管理方式存在着许多缺点,如:效率低、保密性差、人工的大量浪费;另外时间一长,将产生大量的文件和数据,这对于查找、更新和维护都带来了不少困难。随着科学技术的不断提高,计算机科学日渐成熟其强大的功能已为人们深刻认识,它已进入人类社会的各个领域并发挥着越来越重要的作用。作为计算机应用的一部分,使用计算机对学校的各类信息进行管理,具有
4、手工管理无法比拟的优点。例如:检索迅速、查询方便、效率高、可靠性好、存储量大、保密性好、寿命长、成本低等。利用计算机进行学生信息管理,不仅能够保证准确、无误、快速输出,而且还可以利用计算机对有关信息进行查询,检索迅速、查找方便、可靠性高、存储量大、保密性好。要科学地实现信息化管理,开发一个适合学校的,能够进行信息存储、查询、修改等功能的信息管理系统是十分重要的。这些优点能够极大地提高学校信息管理的效率,也是一个单位科学化、正规化管理,与世界接轨的重要条件。本系统是将现代化的计算机技术和传统的教学、教务工作相结合,按照学院的工作流 程设计完成的。通过一个简化的学生信息管理系统,使学生信息管理工作
5、系统化、规范化、自动化,从而达到提高学生信息管理效率的目的。本课题就是针对便于学生信息管理的问题而设计的一个管理系统。1.2 实验技术选择本课题设计主要运用的技术有两个:java 项目开发和 oracle 对数据库的操作。这里主要介绍本课题为什么选用这两个开发技术:首先了解一下 Java 语言特点 Java 是一种跨平台,适合于分布式计算环境的面向对象编程语言。具体来说,它具有如下特性: 简单性、面向对象、分布式、解释型、可靠、安全、平台无关、可移植、高性能、多线程、动态性等。 下面我们将重点介绍 Java 语言的面向对象、平台无关、分布式、多线程、可靠和安全等特性。 面向对象 面向对象其实是
6、现实世界模型的自然延伸。现实世界中任何实体都可以看作是对象。对象之间通过消息相互作用。另外,现实世界中任何实体都可归属于某类事物,任何对象都是某一类事物的实例。如果说传统的过程式编程语言是以过程为中心以算法为驱动的话,面向对象的编程语言则是以对象为中心以消息为驱动。用公式表示,过程式编程语言为:程序=算法+数据;面向对象编程语言为:程序=对象+消息。 所有面向对象编程语言都支持三个概念:封装、多态性和继承,Java 也不例外。现实世界中的对象均有属性和行为,映射到计算机程序上,属性则表示对象的数据,行为表示对象的方法(其作用是处理数据或同外界交互) 。所谓封装,就是用一个自主式框架把对象的数据
7、和方法联在一起形成一个整体。可以说,对象是支持封装的手段,是封装的基本单位。Java 语言的封装性较强,因为 Java 无全程变量,无主函数,在 Java 中绝大部分成员是对象,只有简单的数字类型、字符类型和布尔类型除外。而对于这些类型,Java 也提供了相应的对象类型以便与其他对象交互操作。 多态性就是多种表现形式,具体来说,可以用“一个对外接口,多个内在实现方法”表示。举一个例子,计算机中的堆栈可以存储各种格式的数据,包括整型,浮点或字符。不管存储的是何种数据,堆栈的算法实现是一样的。针对不同的数据类型,编程人员不必手工选择,只需使用统一接口名,系统可自动选择。运算符重载(operator
8、overload)一直被认为是一种优秀的多态机制体现,但由于考虑到它会使程序变得难以理解,所以Java 最后还是把它取消了。 继承是指一个对象直接使用另一对象的属性和方法。事实上,我们遇到的很多实体都有继承的含义。例如,若把汽车看成一个实体,它可以分成多个子实体,如:卡车、公共汽车等。这些子实体都具有汽车的特性,因此,汽车是它们的“父亲” ,而这些子实体则是汽车的“孩子” 。Java 提供给用户一系列类(class) ,Java 的类有层次结构,子类可以继承父类的属性和方法。与另外一些面向对象编程语言不同,Java 只支持单一继承。 平台无关性 Java 是平台无关的语言是指用 Java 写的
9、应用程序不用修改就可在不同的软硬件平台上运行。平台无关有两种:源代码级和目标代码级。C 和 C+具有一定程度的源代码级平台无关,表明用 C 或 C+写的应用程序不用修改只需重新编译就可以在不同平台上运行。Java 主要靠 Java 虚拟机(JVM)在目标码级实现平台无关性。JVM 是一种抽象机器,它附着在具体操作系统之上,本身具有一套虚机器指令,并有自己的栈、寄存器组等。但 JVM 通常是在软件上而不是在硬件上实现。 (目前,SUN 系统公司已经设计实现了 Java芯片,主要使用在网络计算机 NC 上。 另外,Java 芯片的出现也会使 Java 更容易嵌入到家用电器中。 )JVM 是 Jav
10、a 平台无关的基础,在 JVM 上,有一个 Java 解释器用来解释 Java 编译器编译后的程序。Java 编程人员在编写完程序后,通过 Java 编译器将 Java 源程序编译为 JVM 的字节代码。任何一台机器只要配备了 Java 解释器,就可以运行这个程序,而不管这种字节码是在何种平台上生成的。另外,Java 采用的是基于 IEEE 标准的数据类型。通过 JVM 保证数据类型的一致性,也确保了 Java 的平台无关性。 Java 的平台无关性具有深远意义。首先,它使得编程人员所梦寐以求的事情(开发一次软件在任意平台上运行)变成事实,这将大大加快和促进软件产品的开发。其次Java 的平台
11、无关性正好迎合了“网络计算机”思想。如果大量常用的应用软件(如字处理软件等)都用 Java 重新编写,并且放在某个 Internet 服务器上,那么具有 NC 的用户将不需要占用大量空间安装软件,他们只需要一个 Java 解释器,每当需要使用某种应用软件时,下载该软件的字节代码即可,运行结果也可以发回服务器。目前,已有数家公司开始使用这种新型的计算模式构筑自己的企业信息系统。 分布式 分布式包括数据分布和操作分布。数据分布是指数据可以分散在网络的不同主机上,操作分布是指把一个计算分散在不同主机上处理。 Java 支持 WWW 客户机/服务器计算模式,因此,它支持这两种分布性。对于前者,Java
12、 提供了一个叫作 URL 的对象,利用这个对象,你可以打开并访问具有相同 URL 地址上的对象,访问方式与访问本地文件系统相同。对于后者,Java 的 applet 小程序可以从服务器下载到客户端,即部分计算在客户端进行,提高系统执行效率。 Java 提供了一整套网络类库,开发人员可以利用类库进行网络程序设计,方便得实现 Java 的分布式特性。 可靠性和安全性 Java 最初设计目的是应用于电子类消费产品,因此要求较高的可靠性。Java 虽然源于 C+,但它消除了许多 C+不可靠因素,可以防止许多编程错误。首先,Java 是强类型的语言,要求显式的方法声明,这保证了编译器可以发现方法调用错误
13、,保证程序更加可靠;其次,Java 不支持指针,这杜绝了内存的非法访问;第三,Java 的自动单元收集防止了内存丢失等动态内存分配导致的问题;第四,Java 解释器运行时实施检查,可以发现数组和字符串访问的越界,最后,Java 提供了异常处理机制,程序员可以把一组错误代码放在一个地方,这样可以简化错误处理任务便于恢复。 由于 Java 主要用于网络应用程序开发,因此对安全性有较高的要求。如果没有安全保证,用户从网络下载程序执行就非常危险。Java 通过自己的安全机制防止了病毒程序的产生和下载程序对本地系统的威胁破坏。当 Java 字节码进入解释器时,首先必须经过字节码校验器的检查,然后,Jav
14、a 解释器将决定程序中类的内存布局,随后,类装载器负责把来自网络的类装载到单独的内存区域,避免应用程序之间相互干扰破坏。最后,客户端用户还可以限制从网络上装载的类只能访问某些文件系统。 上述几种机制结合起来,使得 Java 成为安全的编程语言。 多线程 线程是操作系统的一种新概念,它又被称作轻量进程,是比传统进程更小的可并发执行的单位。 C 和 C+采用单线程体系结构,而 Java 却提供了多线程支持。Java 在两方面支持多线程。一方面,Java 环境本身就是多线程的。若干个系统线程运行负责必要的无用单元回收,系统维护等系统级操作;另一方面,Java 语言内置多线程控制,可以大大简化多线程应
15、用程序开发。Java 提供了一个类 Thread,由它负责启动运行,终止线程,并可检查线程状态。Java 的线程还包括一组同步原语。这些原语负责对线程实行并发控制。利用 Java 的多线程编程接口,开发人员可以方便得写出支持多线程的应用程序,提高程序执行效率。必须注意地是,Java 的多线程支持在一定程度上受运行时支持平台的限制。例如,如果操作系统本身不支持多线程,Java 的多线程特性可能就表现不出来。 oracle 数据库的特点无范式要求,可根据实际系统需求构造数据库。 采用标准的 SQL 结构化查询语言。具有丰富的开发工具,覆盖开发周期的各阶段。支持大型数据库,数据类型支持数字、字符、大
16、至 4GB 的二进制数据,为数据库的面向存储提供数据支持。具有第四代语言的开发工具(SQL*formS、SQL*REPORTS、SQL*MENU 等) 。具有字符界面和图形界面,易于开发。通过 SQL*DBA 控制用户权限,提供数据保护功能,监控数据库的 运行状态,调整数据缓冲区的大小。 分布优化查询功能。具有数据透明、网络透明,支持异种网络、异构数据库系统。并行 处理采用动态数据分片技术。支持客户机/服务器体系结构及混合的体系结构(集中式、分布式、 客户机/服务器) 。实现了两阶段提交、多线索查询手段。 支持多种系统平台(HPUX、SUNOS、OSF/1、VMS、 WINDOWS、WINDO
17、WS/NT、OS/2) 。数据安全保护措施:没有读锁,采取快照 SNAP 方式完全消除了分布读写冲突。自动检测死锁和冲突并解决。 数据安全级别为 C2 级(最高级) 。 数据库内模支持多字节码制,支持多种语言文字编码。具有面向制造系统的管理信息系统和财务系统应用系统。综上所述,选择 java 作为开发语言,oracle 作为数据库开发工具是个不错的选择。java 语言的面向对象、平台无关、分布式、多线程、可靠和安全等特性,使得开发出来的项目具有健壮性、可维护性、可移植性等特点。Oracle 是目前最具权威的数据库产品,它具有的兼容性、可移植性、可联结性、高生产率和开放性的特点,使它成为当今众多
18、的程序开发人员首选的数据库开发工具。所以本课题选择 java 和 oracle 作为开发技术是为今后开发更复杂的项目打下基础,以免到时候遇到相关的技术问题而不知所措。1.3 课题实现技术的简要说明 本课题主要运用了 java 图形编程和 oracle 数据库的操作。Java 图形编程给用户提供了一个直观、易于与用户进行交互的图形界面。在图形编程中,运用了大量的 java.swing 包中的类,之所以选择 swing 包中的类而不选 java.awt包中的类,主要是 swing 包中的类能给用户提供更好的观感。oracle 数据库的操作这部分内容分成三部分来实现:首先,编写对数据库操作的类,包括
19、:连接数据库、执行 sql 语句、关闭数据库连接等。其次,编写一个用于对学生信息进行数据库操作的类,包括:学生信息的增加、修改、删除和查询等。最后,编写一个用于对课程相关信息进行数据库操作的类,包括:对课程信息的增加、修改、删除、查询等等。通过结合图形编程和数据库编程,从而基本上实现了学生信息管理的基本功能,由于本人技术上的不足,难免有些地方需要改进,这些存在的问题都将成为本人前进的动力,并在日后更加完善本课题的设计。1.4 可行性分析 系统的性质为管理软件,因而数据库的设计与操纵是系统设计的核心。这里从两方面分析技术上的可行性。首先,对于 java 编程部分,java 课已经开过。因此在课题
20、设计中,对 java 图形编程方面的问题都能迎韧而解。其次,对于数据库的有关知识,本人运用了大量的时间对相关书籍的阅读以及上机实验,基本上掌握了运用 oracle 数据库技术,具备一定的系统分析与设计能力,熟悉数据库的设计与操纵;因而该系统的实现在技术上是可行的。2 系统需求分析本课题根据学生信息管理综合分析,便出于方便管理考虑,将学生信息管理系统的功能总结起来,共需要实现以下几个方面功能:管理学生信息管理所有学生的基本信息,对学生信息的操作包括添加、修改、删除等;可以根据各种条件查询出需要的信息,比如修改,可以通过学生学号查询出学生的基本信息,然后通过对需要修改项进行修改并保存修改后的结果存
21、入数据库的学生表中。管理课程信息管理所有课程的基本信息,包括对课程信息的添加、修改、删除等操作;可以根据各种条件查询出需要的信息,并对相应的信息进行操作。比如修改和删除,可以通过学生的学号查询出学生的相应课程信息,对相应的课程进行修改、删除操作。学生选课与成绩根据学生的学号进行选课,登记所选课程的成绩;可以根据学号查询出选课信息与成绩。通过以上功能的设计与实现,并实现学生信息管理系统的基本功能。3 学生信息管理系统设计3.1 数据模型分析与设计数据库模型描述了在数据库中结构化和操纵数据的方法,模型的结构部分规定了数据如何被描述(例如树、表等) ;模型的操纵部分规定了数据的添加、删除、显示、维护
22、、打印、查找、选择、排序和更新等操作。数据库模型的分类:分层模型、关系模型、网络模型和对象模型。本课题选择的关系模型,关系模型是目前最重要的一种数据模型。关系数据库系统采用关系模型作为数据的组织方式。关系数据模型具有下列优点: 关系模型与非关系模型不同,它是建立在严格的数学概念的基础上的。 关系模型的概念单一。无论实体还是实体之间的联系都用关系表示。对数据的检索结构也是关系(即表) 。所以其数据结构简单、清晰,拥护易懂易用。 关系模型的存取路径对用户透明,从而具有更高的数据独立性、更好的安全保密性,也简化了程序员的工作和数据库开发建立的工作。所以,关系数据模型诞生以后发展迅速,深受拥护的喜爱,
23、这也是本课题选取关系数据模型的原因。当然,关系数据模型也有缺点,其中最主要的缺点是,由于存取路件对用户透明,查询效率往往不如非关系数据模型。因此为了提高性能,必须对用户的查询请求进行优化,增加了开发数据库管理系统的难度。本课题的关系数据模型的数据结构可分为三个表来表示:学生信息表(Student) 、课程信息表(Course) 、学生选课表(SC) ;学生信息表用于记录学生的基本信息,如表 3-1;课程信息表用于记录课程的基本信息,如表 3-2;学生选课表如下表 3-3。这三个表对应的 E-R 图分别是:图 3.1 学生信息E-R 图;图 3.2 课程信息 E-R 图;图 3.3 学生选课 E
24、-R 图;如下图。表 3-1 学生信息表(Student)名称 数据类型 主键 非空学号 Number(10) Yes Yes学生姓名 Varchar2 No Yes性别 Char(2) No No年龄 Char(2) No No专业 Varchar2 No No学院 Char(8) No No表 3-2 课程信息表(Course)名称 数据类型 主键 非空课程编号 Char(4) Yes Yes课程名称 Varchar2 No Yes授课教师 Varchar2 No No上课地点 Varchar2 No No课程类别 Char(1) No No表 3-3 学生选课表(SC)名称 数据类型 主
25、键 非空学号 Char(10) Yes Yes课程编号 Char(4) Yes Yes成绩 Number(4,1) No No学生学号 学生姓名性别专业年级 出生图 3.1 学生信息 E-R 图课程课程编号上课地点课程名称授课教师 课程类别图 3.2 课程信息 E-R 图选课表学号课程编号成绩图 3.3 学生选课 E-R 图3.2 结构设计与结构功能图3.2.1 结构设计根据对系统进行需求分析,本系统将分为 4 个模块: 学生管理管理学生基本信息,包括个人信息的添加、修改、删除以及选课信息的添加。 课程管理管理课程的基本信息,包括课程信息的添加、修改和删除。 成绩管理管理学生选课的成绩信息,包
26、括成绩的登记与修改。 信息查询查询已经登记的信息,包括学生的基本信息、课程的基本信息与成绩信息。3.2.2 功能结构图学生管理系统功能结构如图 3.4 所示。学生管理系统学生管理课程管理成绩管理信息查询添加增加删除学生查询增加课程查询修改修改修改删除学生选课成绩查询按姓名查询按学号查询按性别查询按专业查询按学院查询按课程名称查询查询所有科目成绩按授课老师查询图 3.4 学生管理系统功能结构图4 系统实现该系统由 6 个模块构成,包括学生管理系统主界面模块、学生信息管理模块、课程信息管理模块、成绩信息管理模块、信息查询模块和数据操作模块。下面分别加以叙述: 学生管理系统主界面模块学生管理系统主界
27、面模块包括 StuMS.java 和 StuMain.java 两个文件。StuMS 是学生管理系统的主运行类,其中有运行整个程序的 main 方法,该文件生成了 StuMain 类的一个实例,从而生成了学生管理系统的界面,如图 4.1 所示。StuMain 类继承自 JFrame 类,实现了 ActionListener 接口,他有一个不带参数的构造方法 StuMain(),用来生成 StuMain的实例。StuMain 类将所有功能集中到菜单栏中,并通过调用其他模块来实现学生管理系统的各个功能。图 4.1 学生管理系统主界面 学生信息管理模块学生信息管理模块主要由StuInfo.java、
28、AddStuInfo.java、EdiStuInfo.java、DelStuInfo.java 、SelectCourse.java 和StuInfoSearchSnum.java 共计 6 个文件组成,其构成关系如图 4.2 所示。学生信息超类StuInfo.java增加学生信息AddStuInfo.java修改学生信息EdiStuInfo.java删除学生信息DelStuInfo.java学生选课SelectCourse.java按学号查询StuInfoSearchSnum.java按学号查询StuInfoSearchSnum.java图 4.2 学生信息管理模块功能结构图学生信息管理模块
29、的 6 个文件组成了主界面中的“学生管理”菜单的内容,其中包括增加、修改、删除和学生选课功能,如图 4.3 所示。图 4.3 学生信息管理模块的运行界面 课程信息管理模块课程信息管理模块主要由CourseInfo.java、AddCourseInfo.java、EditCourseInfo.java、DelCourseInfo.java 、CourseInfoSearchCnum.java 这 5 个文件组成,其构成关系如图 4.4 所示。课程信息超类CourseInfo.java增加课程信息AddCourseInfo.java修改课程信息EditCourseInfo.java删除课程信息De
30、lCourseInfo.java按课程号查询CourseInfoSearchCnum.java按课程号查询CourseInfoSearchCnum.java图 4.4 课程信息管理模块功能结构图课程信息管理模块中的 5 个类文件组成了主界面中“课程管理”菜单的内容,其中包括增加、修改和删除功能,如图 4.5 所示。图 4.5 课程信息管理模块运行界面 成绩信息管理模块成绩信息管理模块主要由 GradeInfo.java、AddGradeInfo.java、EditGradeInfo.java 这 3个文件组成,其构成关系如图 4.6 所示。成绩管理超类GradeInfo.java增加成绩信息A
31、ddGradeInfo.java修改成绩信息EditGradeInfo.java图 4.6 成绩信息管理模块功能结构图成绩信息管理模块中的 3 个类文件组成了主界面中的“成绩管理”菜单的内容,其中包括增加和修改功能,如图 4.7 所示。图 4.7 成绩信息管理模块的运行界面 信息查询模块信息查询模块主要包括学生查询、课程查询和成绩查询 3 个部分。信息查询的运行主截面如图 4.8 所示。图 4.8 学生信息查询模块的运行界面学生查询由StuSearchSnum.java、StuSearchSsex.java、StuSearchScollege.java、StuSearchSmajor.java
32、 和ResultStudent.java 这 6 个文件组成,主要实现功能包括:按学号查询、按学生姓名查询、按性别查询、按学院查询与按专业查询。5 系统调试与测试5.1 系统功能测试功能测试主要是测试程序模块是否实现了设计中所要求的功能。功能测试中需要注意的有:(1)查询功能中,有按单一查询条件进行查询的,也有按多个查询条件组合查询的。这里要注意的多个查询条件之间的关系。还有一些常识性的问题,比如按月查询,闰月中二月的天数。(2)录入功能中,需要注意的是前台设置的数值长度是否大于后台数值长度,以及前台和后台的数据结构是否相符,很多时候录入功能无法实现是由于这些原因。还有就是必须录入的字段的设置
33、时候有误。(3)测试删除功能中需要注意的是单击“删除“按钮后,一般会出现提示信息,询问是否确定删除。通常情况下,我们单击“确认“按钮查看信息是否被删除掉了,而忽略了单击“取消“按钮后程序的反应:这时有可能的是没有删除,还有一种可能是即便单击了“取消“按钮,也一样删除了数据。另外,在删除多条记录的时候,要注意连续选中的几条记录是否真正都被删除掉了,即如果再按照这种查询方式查询,时候还能查询出来。有的时候需要在数据库中设立一个标志位,而不是真正的物理删除。所以在下一次查询中,可能还会被查询出来,这主要是因为在查询条件中没有将标志考虑在内。(4)关于修改功能的测试主要是看修改确认后是否数据真正已被修
34、改了。这是最基本的功能,需要注意的是看是否能把不应该修改的数据也修改成功了。 5.2 系统调试常见错误1.NullPointerException 异常一般是对一个为 NULL 值的变量进行操作引起的。为避免这种异常,最好在对变量操作之前检查,看它是否为 NULL 值。2.SQLException 异常一般是由于 SQL 语句不正确引起的。为避免这种异常,最好在使用 SQL 语句的程序中捕获此 SQL 异常。3.NumberFormatException 异常这是由于数字的格式错误而出现的例外。为了避免出现此类错误,一般必须保证数据格式输入正确。4.数据库连接垃圾回收在实际的开发应用中,通常出
35、现某一个对象未能关闭的情况,为了防止这种情况的发生,可以在有关对数据库操作的 Java 类文件中增加自动回收函数,在 JVM 自动地回收对象时,取出使用的连接对象,判断是否关闭,如果没有关闭则关掉。代码如下所示:protected void finalize()tryIf(getConn()!=nullstm.close();conn.close();catch(SQLException e)6 实验小结经过这次课题的设计并实现,尽管会遇到很多难题,但是让我更加受益的是在这次课题中得到的经验、心得和锻炼。我发现做实验的过程其实就是个不断的解决问题的过程,从中也感觉到实验成功的快乐,一个人永远有
36、学不玩的知识,就算是实验中的知识点都学了,但在实际的应用过程中仍然会遇到不少问题,遇到问题时要做到两点:一个是“查”,一个是“问” 。不懂的地方就得要自己找答案,可以从书本、网络中查找解决的答案;再一个就是问周边的同学。这次课程的设计给我所学的知识做了一个总结,为我深入学习编程做了铺垫。在本课题中存在的不足之处是在所难免的,本人将在日后加于改进。参考文献1 王克宏、郝建文 . Java 技术教程 M. 北京:清华大学出版社,2002 年 9 月.2 蔡敏、徐慧慧、黄炳强. UML 基础与 Rose 建模教程 M. 北京:人民邮电出版社,2006 年 5 月.3 萨师煊、王珊. 数据库系统概论(
37、第三版)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.javapackage com.main;impor
38、t java.awt.event.ActionEvent;import java.awt.event.ActionListener;import java.sql.Connection;import javax.swing.JButton;import javax.swing.JComboBox;import javax.swing.JFrame;import javax.swing.JLabel;import javax.swing.JTextField;import javax.swing.JOptionPane;import com.bean.Student;import com.dao
39、.StudentDao;import com.db.DB;import com.main.DelteStudent.delAction;public class AddStuInfo extends JFrame StudentDao studao = new StudentDao();DB db = new DB();Connection conn = db.getConnection();JTextField snoText = null;JTextField snameText = null;JComboBox sexcom = null;JTextField ageText = nul
40、l;JComboBox classcom = null;JComboBox departcom = null;public void init() / 窗体设计this.setLayout(null);this.setTitle(“学生信息管理系统“);this.setSize(500, 400);JLabel title = new JLabel(“学生信息维护模块-录入数据“);title.setBounds(180, 20, 200, 30);this.add(title);JLabel snoLabel = new JLabel(“学号“);snoText = new JTextFie
41、ld();snoLabel.setBounds(20, 60, 40, 25);snoText.setBounds(60, 60, 120, 25);this.add(snoLabel);this.add(snoText);JLabel snameLabel = new JLabel(“姓名“);snameText = new JTextField();snameLabel.setBounds(220, 60, 40, 25);snameText.setBounds(260, 60, 120, 25);this.add(snameLabel);this.add(snameText);JLabe
42、l sexlabel = new JLabel(“性别“);String sex = “男“, “女“ ;sexcom = new JComboBox(sex);sexlabel.setBounds(20, 90, 40, 25);sexcom.setBounds(60, 90, 120, 25);this.add(sexlabel);this.add(sexcom);JLabel ageLabel = new JLabel(“年龄“);ageText = new JTextField();ageLabel.setBounds(220, 90, 40, 25);ageText.setBound
43、s(260, 90, 120, 25);this.add(ageLabel);this.add(ageText);JLabel classlabel = new JLabel(“班级“);String classes = “信息 081“, “信息 082“, “物流 081“ ;classcom = new JComboBox(classes);classlabel.setBounds(20, 120, 40, 25);classcom.setBounds(60, 120, 120, 25);this.add(classlabel);this.add(classcom);JLabel dep
44、artlabel = new JLabel(“学院“);String depart = “造纸“, “理学院“, “机电学院“ ;departcom = new JComboBox(depart);departlabel.setBounds(220, 120, 40, 25);departcom.setBounds(260, 120, 120, 25);this.add(departlabel);this.add(departcom);/ 录入数据JButton addbtn = new JButton(“录入“);addbtn.setBounds(150, 180, 60, 30);addb
45、tn.addActionListener(new addAction();this.add(addbtn);/ 返回JButton backbtn = new JButton(“返回“);backbtn.setBounds(230, 180, 60, 30);backbtn.addActionListener(new BackAction ();this.add(backbtn);this.setLocationRelativeTo(null); / 使窗体居中this.setResizable(false);/ 固定窗体大小this.setVisible(true); / 设置窗体可见/th
46、is.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); / 窗体关闭时,程序结束/ 获取文本框或选择框的值public Student getStudent() Student stu = new Student();String sno = snoText.getText(); / 获取输入的学号String sname = snameText.getText(); / 获取姓名String sex = (String) sexcom.getSelectedItem();/ 获取性别int age = Integer.parseInt(ageTe
47、xt.getText().trim(); / 获取年龄String className = (String) classcom.getSelectedItem(); / 获取班级String depart = (String) departcom.getSelectedItem(); / 获取学院/ 封装信息stu.setSno(sno);stu.setName(sname);stu.setSex(sex);stu.setAge(age);stu.setClassName(className);stu.setDepart(depart);return stu;public static voi
48、d main(String args) AddStudent addstu = new AddStudent();addstu.init();/ 录入的监听器class addAction implements ActionListener public void actionPerformed(ActionEvent e) Student stu = getStudent();boolean b = studao.save(stu, conn);if (b) JOptionPane.showMessageDialog(null, “数据录入成功!“); else JOptionPane.sh
49、owMessageDialog(null, “学号已存在,数据录入失败!“);class BackAction implements ActionListenerpublic void actionPerformed(ActionEvent e) MainFrame m=new MainFrame ();m.init();/DelStuInfo.javapackage com.main;import java.awt.event.ActionEvent;import java.awt.event.ActionListener;import java.sql.Connection;import java.sql.SQLException;import java.util.Vector;import javax.swing.JButton;import javax.swing.JComboBox;import javax.swing.JFrame;import javax.swing.JLabel;import ja