1、 教务管理系统的设计与实现摘 要教务管理是学校的教务工作的主要内容,其信息量大、信息变动频繁历来是各学校的头疼问题,随着人们对用计算机的使用越来越广泛以及互联网络普及,教务管理也已经基本形成了多元的网络化管理,极大的方便了广大师生,也方便了学校对教务工作的管理,大大的提高了教学质量。本系统采用 FlexBuilder、MyEclipse 结合 MySQL 数据库进行设计,从管理和使用的角度分为两个部分:学校教务管理端和学生使用端。前者主要有系统管理员及任课教师使用,后者则是主要面对在校学生。本文首先作教务管理系统的功能需求分析,然后对数据库进行需求分析,再在数据库中建立相应的表,并弄清楚数据库
2、中各个表的逻辑关系,接着编写代码,最后调试网站,直到形成用户满意的可以使用的完整系统。关键词: 教务管理系统; FlexBuilder; MyEclipse; MySQLThe Design and Implementation of Educational Administration SystemAbstractAcademic Senate, the school management is the main content, it is informative, information has always been the frequent changes in schools of
3、 headache problems, as people used more and more extensive use of computers and the popularization of the Internet, educational administration has been basically formed a multi-network management, a great convenience to teachers and students, but also on the Senate to facilitate the work of the scho
4、ol management, greatly increased the quality of teaching.The system uses a FlexBuilder, MyEclipse combination of MySQL database design, from the perspective of management and use is divided into two parts: School of Educational Administration and students to use the client side. The former are mainl
5、y system administrators and classroom teachers to use, while the latter is the major problems encountered in school.In this paper, first of all, make the functions of educational management system needs analysis, then the database needs analysis, and then in the database corresponding table, and eac
6、h database table to clarify the logic of relations, and then write code, debug the final site, until the formation of customer satisfaction The complete system can be used.Keywords: Educational Administration system; FlexBuilder; MyEclipse; MySQL目 录1 绪 论 .11.1 课题的研究背景与意义 11.1.1 课题的研究背景 .11.1.2 课题的研究
7、意义 .11.2 系统的定义及内容简介 11.2.1 系统的定义 .21.2.2 系统的内容简介 .22 系统中主要用到的技术 .32.1 MySQL 数据库 .32.2 Flex 32.3 Java 43 教务管理系统的设计与实现 63.1 开发和运行环境选择 63.2 系统设计 63.2.1 系统 功能分析 .63.2.2 系统功能模块设计 .73.3 数据库设计 73.3.1 数据库概念结构设计 .73.3.2 数据库逻辑结构设计 .84 模块详细设计 114.1 主页面 .114.2 用户登录页面 .134.3 学生功能模块设计 .174.3.1 个人信息查询页面 174.3.2 个人
8、信息修改页面 214.3.3 在线选课页面 224.3.4 密码修改页面 274.3.5 历史留言查询页面 274.3.6 留言板页面 284.4 教师功能模块设计 .294.4.1 教学实施计划查询页面 294.4.2 选课信息查询页面 304.4.3 个人信息查询修改页面 304.4.4 密码修改页面 304.5 管理员功能模块设计 .314.5.1 教师信息修改、删除页面 314.5.2 管理员信息修改、删除页面 324.5.3 课程信息添加、修改、删除页面 324.5.4 学生学籍查询、修改、删除页面 344.5.5 留言查看、删除页面 355 用户 手册 365.1 系统功能简介 .
9、365.2 系统运行与操 作指 南 .366 总结与展望 376.1 系统总结及不足之处 .376.2 设计心 得 .37致 谢 .39参考文 献 40附录 1 外文参考 文献(译文) .41附录 2 外文参考文 献(原文) .441 绪论1.1 课题的研究背景与意义1.1.1 课题的研究背景目前我国各行各业的信息化建设开展得如火如荼,这种信息化的发展已经影响到了各学校。学校在对学生进行管理时,学生学籍的管理一直都是很麻烦的事情,不仅仅管理起来不易修改和更新,而且学生需要了解本人的信息时,也需要去学校教务处找专门人员。由于这些操作的繁琐性,教务管理系统的开发成为各学校必须的事情,特别是各个高校
10、。一个成功的教务管理系统,应该能够有效地辅助教务人员工作,提高学校学生的学籍、成绩等管理能力,并且不断完善系统,以便更好的帮助学生、教师、系统管理人员等管理成绩、课程、学籍等。然而目前许多教务管理系统在使用时,效率低下容易出错,学生、教师资料不易整理,大量丢失,这些无疑都已成为管理学生学籍、教师信息的障碍。这就要求学校能够建立高效的教务管理系统,对学生的选课、查询等操作及流程进行规范化管理,简化业务流程,提高工作效率并防止中间的漏洞;迅速、准确地捕捉用户要求,并加以高效回应。同时需要不断完善系统,增加模块,更好的满足用户需求,简化教务人员的管理工作,尽量做到一切信息化。 1.1.2 课题的研究
11、意义对于学校教务处而言,最主要的是管理学生的学籍、管理教师的课程教授。如果使用一般的方法来管理,会比较繁琐,管理起来也很有可能出错。为了方便教务人员的管理工作,提高工作效率,同时为了更好地为学生、教师提供服务,有必要开发教务管理系统,使学校的教务管理走上信息化之路,克服人为的种种弊端。教务管理系统的开发不仅可以减少人力、物力和财力资源的浪费,更重要的是有助于提高教务管理的效率。教务管理人员管理学生学籍、管理教师课程教授时是一项复杂的组织工作,这种复杂性不仅仅指学生学籍变更快,变更人数众多,更突出地表现在教务管理主要对象(即学生)的数据量大,管理起来带来不便,所以开发一个实用、高效的教务管理信息
12、系统是很有必要的。1.2 系统的定义及内容简介1.2.1 系统的定义本系统是方便学校教务人员管理学生学籍、管理教师、方便教师和学生处理日常学籍工作而开发的。现今全国各学校的管理系统正逐步与网络信息技术接轨,对学校的学员信息能够更方便地进行管理,运用教务管理系统实现管理模式的科学化、现代化,大大提高学校教务管理的运行效率和管理水平。因此,在科技、信息和网络技术高速发展的带动下,教务管理系统趋向于集计算机网络技术、科学管理方法等于一体,方便处理教务工作。由于学校教务管理的特殊性,决定了教务服务的综合性较其他服务更为突出和特殊,而学校教务对用于辅助管理的管理系统要求就相对更高。对于学校教务而言,具有
13、实用意义的管理系统,在硬件上应采用互联网、办公自动化等信息技术,在软件上应融入当代各学校最优秀的管理思想,从而更好地辅助教务人员的管理工作。本课题就基于教务管理的理念和信息技术的结合这样一个出发点而提出的需要。我国的各学校教师、学生人数众多,学校需要一个足够完善的教务管理系统来管理学生的学籍、选课和教师的授课安排等,所以本系统提供了对学生的学籍管理、对学生的选课、对教师的信息管理等功能,足够教务人员管理日常的教务工作。1.2.2 系统的内容简介教务管理系统为教务管理人员管理日常教务工作提供了方便。学生可以使用此系统查询自己已修完课程的成绩、查看自己的学籍信息、选课等;教师可以使用此系统给学生所
14、选的课程打分、查看自己的信息及课程安排情况等;管理员可以使用此系统添加相关用户信息、备份数据等。因此本系统主要实现学生功能、教师功能、管理员功能。学生功能:个人信息查询、修改;在线选课;密码修改;留言、查看留言等。教师功能:教学实施计划查询;选课信息查询、打分;个人信息查询、修改;密码修改等。管理员功能:教师信息修改、删除;管理员信息修改、删除(有权限之分) ;课程信息添加、修改、删除;学生学籍信息查询、修改、删除(有权限之分) ;留言查看、删除(有权限之分)等。2 系统中主要用到的技术2.1 MySQL 数据库MySQL 是一个遵循 GPL 的开源软件、在 Linux 平台底下它是 LAMP
15、(LAMP 代表了 Linux 平台上的 Apache 网站服务器;MySQL 数据库以及 Perl、Python 或者 PHP编程语言的结合)组合重要组成部分,同时它提供的 C API 可以结合 Glade/GTK+,代替 Windows 平台的 VB+ACCESS/MS SQL SERVER 组合。MySQL 数据库具有以下特性: 使用 C 和 C+编写,并使用了多种编译器进行测试,保证源代码的可移植性。 支持 AIX、FreeBSD、HP-UX、Linux、Mac OS、Novell Netware、OpenBSD、OS/2 Wrap、Solaris、Windows 等多种操作系统。 为
16、多种编程语言提供了 API。这些编程语言包括C、C+、Eiffel、Java、Perl、PHP、Python 、Ruby 和 Tcl 等。 支持多线程,充分利用 CPU 资源。 采用优化的 SQL 查询算法可以有效地提高查询速度。 既能够作为一个单独的应用程序应用在客户端/服务器网络环境中,也能够作为一个库而嵌入到其他的软件中提供多语言支持,常见的编码如中文的GB2312、BIG5,日文的 Shift_JIS 等都可以用作数据表名和数据列名。 提供 TCP/IP、ODBC 和 JDBC 等多种数据库连接途径 。 提供用于管理、检查、优化数据库操作的管理工具。 可以处理拥有上千万条记录的大型数据
17、库。2.2 FlexAdobe Flex 是支持 RIA(Rich Internet Applications)开发和部署一系列发展中的技术和产品线的概括词,主要包括 the Flex Framework,Flex Builder 2,Flex Enterprise Services 2 等。 FLEX 试图通过提供一个程序员们已经熟知的工作流和编程模型,让程序员比从前更快更简单地开发动画及 RIA 应用。在多层式开发模型中, FLEX 应用属于表现层,FLEX 的语言和文件结构也试图把应用程序的逻辑从设计中分离出来。Adobe Flex 所包含的产品和相关软件如下所述: Flex Frame
18、work 包括 MXML,类库,组件,容器和效果(effects )等,它不需另外的服务器或 IDE 就可以生成和美化 FLEX 应用程序。 Flex Builder 2 是在 Eclipse 基础上创建的全新 RIA IDE,是生成 FLEX 应用的最简单最强大的方式,实现了集成编译器、代码缩进、调试、设计视图、源代码控制系统集成等许多功能。它可以当作标准的独立应用软件,也可以当作Eclipse 的插件使用。 Flex Enterprise Services 2 是 Flex 1.5 server 的下一代,拥有众多新功能,比如自动测试,企业通信支持(提供一种发布/订阅的通信架构) ,数据服
19、务(使本地处理的数据和服务器端同步)等。 Flex Charting 2 提供平滑的数据可视能力,可看作是 Flex Framework 的扩展。 Flex 编译器,被包含于 Flex Builder 2 和 Flex Enterprise Services,但可以在命令行方式下单独使用。 ActionScript 3 是 Flex Framework 的核心,更加面向对象化和类型化,全面兼容ECMA Script 标准(Java Script 2.0 的基础标准) 。 Flash Player,从 8.5 版本就开始加入 AS3 虚拟机,作为 FLEX 2 应用的运行时。FLEX 最初是作为
20、一个 J2EE(Java 2 Platform,Enterprise Edition)应用,或者可以说是 JSP(Java Server Pages)标签库而发布的。它可以把运行中的 MXML(FLEX 标记语言)和 ActionScript 编译成 FLASH 应用程序(即二进制的 SWF 文件) 。相对于基于 HTML 的应用(如 PHP,ASP ,JSP 等)在每个请求时都需要执行服务器端的模板,由于客户端只需要载入一次,FLEX 应用程序的工作流被大大改善。新版的 Flex Builder 2 基于 Eclipse IDE,对于需要诸如 data push 和自动测试等高级功能的用户来
21、说,企业级的服务仍然有效。Flex2 引入了新版本的语言 ActionScript 3的使用,这需要 Flash Player 9 以上版本作为运行时(runtime)。 2.3 JavaJava 是由 Sun 公司于 1995 年 5 月推出的程序设计语言(以下简称 Java 语言)和Java 平台的总称。用 Java 实现的 Hot Java 浏览器显示了 Java 的魅力,可实现跨平台、动态的 Web、Internet 计算。从此, Java 被广泛接受并推动了 Web 的迅速发展,常用的浏览器现在均支持 Java Applet;另一方面,Java 技术也不断更新。Java 语言是一种简
22、单的,面向对象的,分布式的,解释型的,健壮安全的,结构中立的,可移植的,性能优异、多线程的动态语言。而 Java 平台由 Java 虚拟机(Java Virtual Machine)和 Java 应用编程接口(Application Programming Interface,简称 API)构成。 Java 应用编程接口为 Java 应用提供了一个独立于操作系统的标准接口,可分为基本部分和扩展部分。在硬件或操作系统平台上安装一个 Java 平台之后,Java 应用程序就可运行。现在 Java 平台已经嵌入了几乎所有的操作系统。这样 Java 程序可以只编译一次,就可以在各种系统中运行 。3 教
23、务管理系统的设计与实现3.1 开发和运行环境选择教务管理系统主要用于学校内部资源管理(如学生在线选课、成绩查看、学籍查看等) ,充分利用现代高度信息化手段来接受学生信息的咨询和反馈,形成目前学校内部受欢迎的教务产品,同时也方便了教务管理人员的管理工作,也方便了学生对自己个人信息的实时了解。1、开发工具的选择用 Tomcat 作 Web 服务器,利用 My Eclipse 设计代码,使用 MySQL 建立数据库。2、运行环境要求 中央处理器:Inter Pentium 4 2.67GHz 或更高性能的 CPU(推荐使用 P4 3.0GHz 以上) 。 操作系统:Microsoft Windows
24、 XP /Vista,或 Windows2003(或更高) 。 物理内存:512MB (推荐使用 1G 以上) 。 硬盘空间:至少需要 2G 硬盘空间。 光驱。 VGA 监视器。 鼠标或其他定位装置。 网络支持:任何与 Windows 98/NT/2000/Me 兼容的网络。3.2 系统设计3.2.1 系统功能分析教务管理系统主要具有以下功能要求: 学生功能:个人信息查询、修改;在线选课,密码修改;留言、查看留言等。 教师功能:教学实施计划查询;选课信息查询、打分;个人信息查询、修改;密码修改等。 管理员功能:教师信息修改、删除;管理员信息修改、删除(有权限之分) ;课程信息添加、修改、删除;
25、学生学籍查询、修改、删除(有权限之分) ;留言查看、删除(有权限之分)等。3.2.2 系统功能模块设计根据系统功能要求分析,可以将系统分解成以下几个功能模块来设计,如图 3.1 所示。教务管理系统学生 管理员个人信息查询、修改教师在线选课 密码修改留言、留言查看 教学实施计划查询 选课信息查询、打分 个人信息查询、修改密码修改教师信息修改、删除 管理员信息修改、删除课程信息添加课程信息修改删除 学生学籍修改、删除 留言查看、删除图 3.1 系统功能模块图3.3 数据库设计数据库是信息管理系统的基础,数据库的结构直接关系到各种功能的实现和程序运行的效率。3.3.1 数据库概念结构设计数据库概要结
26、构设计图如图 3.2 所示。图 3.2 数据库结构设计图3.3.2 数据库逻辑结构设计根据数据库结构设计图,可知在数据库中需建立 8 张表。本系统创建的数据库为education,该数据库由学生信息表单(stuinfo) 、教师信息表单( teachinfo) 、管理员表单(manainfo) 、教学实施计划表单( teachingplan) 、教学班表单(teachclassinfo ) 、留言板表单(leavewordinfo ) 、课程信息表单(courseinfo) 、选课信息表单(selectcourseinfo)组成,在设计中所用到的关系表及其结构分别如下所示。1、学生信息表单(s
27、tuinfo) ,如表 3.1 所示。表 3.1 学生信息表单列值 数据类型 数据长度 可否为空 描 述 主键stu_id varchar 30 否 学号name varchar 10 否 姓名password varchar 30 否 密码sex varchar 2 否 性别speciality varchar 30 否 专业academe varchar 30 否 学院grade varchar 30 否 年级overcourse varchar 30 否 已学课程achievement varchar 30 否 成绩status varchar 30 否 学籍状态2、教师信息表单(tea
28、chinfo) ,如表 3.2 所示。表 3.2 教师信息表单列值 数据类型 数据长度 可否为空 描 述 主键teach_id varchar 30 否 教师工号name varchar 30 否 姓名password varchar 30 否 密码speciality varchar 30 否 所在专业post varchar 30 否 职称teachcourse varchar 30 否 所授课程3、管理员表单(manainfo ) ,如表 3.3 所示。表 3.3 管理员表单列值 数据类型 数据长度 可否为空 描 述 主键mana_id varchar 30 否 编号username v
29、archar 30 否 管理员名password varchar 30 否 密码popedom varchar 30 否 权限4、教学实施计划表单(teachingplan) ,如表 3.4 所示。表 3.4 教学实施计划表单列值 数据类型 数据长度 可否为空 描 述 主键id int 11 否 编号 是course_name varchar 30 否 课程名course_kind varchar 30 否 课程性质begin_term varchar 30 否 开课学期begin_speciality varchar 30 否 开课专业period varchar 30 否 学时5、教学班表
30、单(teachclassinfo) ,如表 3.5 所示。表 3.5 教学班表单列值 数据类型 数据长度 可否为空 描 述 主键id int 11 否 编号 是specility varchar 30 否 专业grade varchar 30 否 年级stu_num varchar 30 否 学生人数course_name varchar 30 否 课程名6、留言板表单(leavewordinfo) ,如表 3.6 所示。表 3.6 留言板表单列值 数据类型 数据长度 可否为空 描 述 主键leave_id int 11 否 留言编号 是leave_date date 0 否 留言日期leav
31、e_name varchar 30 否 留言人姓名leave_content varchar 2000 否 留言内容7、课程信息表单(courseinfo) ,如表 3.7 所示。表 3.7 课程信息表单列值 数据类型 数据长度 可否为空 描 述 主键course_id varchar 30 否 课程编号 是course_name varchar 30 否 课程名称8、选课信息表单(selectcourseinfo) ,如表 3.8 所示。表 3.8 选课信息表单列值 数据类型 数据长度 可否为空 描 述 主键course_id varchar 30 否 课程号stu_id varchar 3
32、0 否 选修学生学号teacher varchar 30 否 授课教师achievement varchar 30 否 成绩4 模块详细设计4.1 主页面此教务管理系统的用户有三种身份,即学生、教师和系统管理员, 如果是系统管理员,登录后进入的主页面如图 4.1 所示:图 4.1 系统管理员主页面此界面中包含五个功能模块,即管理教师、管理员管理、课程信息管理、学生学籍管理、留言维护。系统管理员在此页面中可对教师、管理员及学生等信息进行浏览、修改、删除、添加等操作。如果是登录用户是学生,登录后进入的主页面如图 4.2 所示。图 4.2 学生主页面此页面包含六个功能模块,即选课、个人信息查询、个人
33、信息修改、密码修改、历史留言查询、留言,学生可以在此页面中对其个人信息分别进行浏览、修改等操作。如果是登录用户是教师,登录后进入的主页面如图 4.3 所示:图 4.3 教师管理主页面此页面包含五个功能模块,即教学实施计划查询、选课信息查询和打分、个人信息查询、个人信息修改、密码修改,教师可在此页面中对相关信息进行浏览、修改等操作。4.2 用户登录页面此页面的主要功能是对使用本系统的用户进行用户名、密码、用户身份的验证,只有合法的用户才能使用本系统。对于初次使用本系统的用户,首先必须是在此学校有学籍,而且教务人员已经将学生、教师、管理员信息写入数据库之后才能访问登录用户界面,此系统不支持陌生人注
34、册。在登录界面中设置了身份列表下拉框,方便用户进行身份选择、登录。用户填写的所有信息通过 Flex 与 Java 的远程调用,通过send()方法将获取的 text 文本提交到 Java 端,并与数据库中的相应信息进行比较做出判断。登录界面如图 4.4 所示。图 4.4 用户登录界面用户登录界面的主要实现代码如下:Event(name=“loginevent“,type=“com.education.events.LoginEvent“)Event(name=“studentloginevent“,type=“com.education.events.StudentLoginEvent“)Ev
35、ent(name=“teacherloginevent“,type=“com.education.events.TeacherLoginEvent“)username.textpassword.texttypes.text4.3 学生功能模块设计学生功能模块主要包括个人信息查询、修改,在线选课,密码修改,留言、查看留言。学生选课,修满学时之后,由授课教师打分,然后学生再次查询信息时则可查询到分数。4.3.1 个人信息查询页面个人信息查询页面如图 4.5 所示,当前登录的学生可在此页面中查看自己的基本信息。图 4.5 个人信息查询页面在个人信息查询页面中,通过 studetLO.getTheSt
36、udent.send()方法来操作数据库,把数据库中的内容用 datagrid 显示出来。首先,将进行查询、修改、删除、增加等操作需要与数据库连接的代码单独封装为一个类,具体代码如下所示:package com.education;import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;import javax.sql.rowset.CachedRowSet;import co
37、m.sun.rowset.CachedRowSetImpl;public class DBTools String driver = “com.mysql.jdbc.Driver“;String url = “jdbc:mysql:/127.0.0.1:3306/education“;String user = “root“;String password = “123456“;Connection con = null;ResultSet rs = null;public DBTools() try Class.forName(driver);con = DriverManager.getC
38、onnection(url, user, password); catch (Exception e) e.printStackTrace();public ResultSet select(String sql) Statement st = null;CachedRowSet crs = null;try st = con.createStatement();ResultSet rs = st.executeQuery(sql);crs = new CachedRowSetImpl();crs.populate(rs); catch (SQLException e) e.printStac
39、kTrace(); finally if (con != null) try con.close(); catch (SQLException e) e.printStackTrace();return crs;public int update(String sql) / 此方法 int 与 boolean 类型都可以Statement st = null;int var = 0;try st = con.createStatement();int i = st.executeUpdate(sql);if (i = 1) var = 1; catch (SQLException e) e.p
40、rintStackTrace(); finally if (con != null) try con.close(); catch (SQLException e) e.printStackTrace();return var;其中使用的数据库操作语句为: public List getTheStudent(String stu_id) List list = new ArrayList();DBTools db = new DBTools();String sql = “select * from stuinfo where stu_id=“ + stu_id + “;ResultSet r
41、s = db.select(sql);Student student = null;try while (rs.next() student = new Student();student.setAcademe(rs.getString(“academe“);student.setAchievement(rs.getString(“achievement“);student.setGrade(rs.getString(“grade“);student.setName(rs.getString(“name“);student.setOvercourse(rs.getString(“overcou
42、rse“);student.setPassword(rs.getString(“password“);student.setSex(rs.getString(“sex“);student.setSpeciality(rs.getString(“speciality“);student.setStatus(rs.getString(“status“);student.setStu_id(rs.getString(“stu_id“);list.add(student); 4.3.2 个人信息修改页面个人信息修改页面如图 4.6 所示,在该页面中学生可对自己的个人信息进行修改。图 4.6 个人信息修
43、改页面每个 Text 文本框中的信息是通过传递 stu_id,通过 stu_id 在数据库中查询出相应的值,然后显示在此页面上,方便用户对比进行修改,修改信息的主要代码如下所示:public boolean modifystudentinfo(String stu_id, String name, String sex,String speciality, String academe, String grade) boolean flag = false;String sql = “update stuinfo set name=“ + name + “,sex=“ + sex+ “,spe
44、ciality=“ + speciality + “,academe=“ + academe+ “,grade=“ + grade + “ where stu_id=“ + stu_id + “;if (sex.equals(“男“) | sex.equals(“女“ ) DBTools tool = new DBTools();int rs = tool.update(sql);if (rs = 1) flag = true; return flag;stu_id.textstudentname.textsex.textspeciality.textacademe.textgrade.tex
45、t4.3.3 在线选课页面学生在线选课页面如图 4.7 所示,在此页面中学生可根据教务安排的选修课情况对自己感兴趣的课程进行选择,但是课程一经选定不允许退选。图 4.7 在线选课页面实现该页面的功能代码如下所示:public List SelectCourse() List list = new ArrayList();DBTools db = new DBTools();String sql = “select * from teachingplan where course_kind=2“;ResultSet rs = db.select(sql);TeachPlan teachplan
46、= null;try while (rs.next() teachplan = new TeachPlan();teachplan.setId(rs.getInt(“id“);teachplan.setCourse_name(rs.getString(“course_name“);teachplan.setCourse_kind(rs.getString(“course_kind“);teachplan.setBegin_term(rs.getString(“begin_term“);teachplan.setBegin_speciality(rs.getString(“begin_speci
47、ality“);teachplan.setPeriod(rs.getString(“period“);list.add(teachplan); catch (SQLException e) e.printStackTrace(); finally try rs.close(); catch (SQLException e) e.printStackTrace();return list;public boolean addcourses(String stu_id, String overcourse) boolean flag = false;boolean b = checkcourse(
48、stu_id,overcourse);DBTools tool = new DBTools();if (b) addcoursetoselect(stu_id,overcourse);List list = getTheStudent(stu_id);String name = list.get(0).getName();String password = list.get(0).getPassword();String sex = list.get(0).getSex();String speciality = list.get(0).getSpeciality();String acade
49、me = list.get(0).getAcademe();String grade = list.get(0).getGrade();String status = list.get(0).getStatus();String sql= “insert into stuinfo values(“ + stu_id + “,“ + name+ “,“ + password + “,“ + sex + “,“ + speciality+ “,“ + academe + “,“ + grade + “,“ + overcourse+ “,0,“ + status + “)“;int rs = tool.update(sql);if (rs = 1)