百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

java实践设计——教务管理系统 内包含源码+sql+项目报告

yuyutoo 2024-10-12 00:40 5 浏览 0 评论

《教务管理系统》

项目报告

题 目: 教务管理系统


目 录

第1章 需求分析- 1 -- 1 -

1.1 需求描述- 1 -- 1 -

1.2 业务流程图- 1 -- 1 -

1.3 用例图- 2 -- 2 -

第2章 系统设计- 4 -- 4 -

2.1 系统的功能结构图- 4 -- 4 -

2.2 数据库的设计- 5 -- 5 -

2.2.1 概念模型设计- 5 -- 5 -

2.2.2 逻辑模型设计- 5 -- 5 -

2.2.3 物理模型设计- 6 -- 6 -

第3章 系统实现- 10 -- 10 -

3.1 实现环境- 10 -- 10 -

3.2 开发框架- 10 -- 10 -

3.3主要功能的开发流程- 10 -- 10 -

3.3.1 课程管理功能- 10 -- 10 -

3.3.2 选课管理功能- 13 -- 13 -

3.3.3 成绩管理功能- 15 -- 15 -

第4章 总结- 19 -- 19 -

第1章 需求分析

开发此系统,可以管理员及操作者更加方便随时添加、查询、修改,提高工作效率,尽量达到人力与设备的节省,面向管理员、学生和教师。

1.1 需求描述

本系统为选课式的管理模式,集学生信息管理、班级信息管理、教师信息管理、选课退课管理、成绩管理、课程安排管理、修改密码功能于一体,并可以打印学生个人成绩单。

1.2 业务流程图

本系统的流程主要描述的是学生打开选课管理来选择课程,如选错还可以退课,最后教师可以看到自己所授课程的所有学生并为其打分。因此,本系统包括3个基本流程。

图1-1描述的是管理员的操作流程:对班级、学生、教师及系统用户数据初始化后,开设新课并设置相关课程安排。

图1-1 业务流程图(管理员)

图1-2描述的是学生的操作流程:学生根据用户名密码登陆系统,初始密码由管理员提供,可自己修改。登陆系统后,可以进行选课、退课和查看成绩、个人信息。

图1-2 业务流程图(学生)

图1-3描述的是教师的操作流程:教师根据用户名密码登陆系统,初始密码由管理员提供,可自己修改。登陆系统后,可以进行所授课和查看成绩、个人信息。

图1-3 业务流程图(教师)

1.3 用例图

根据系统总体设计的模块划分和用户需求分析,设计出系统的用例图,其中的用户具体为管理员、教师、学生,根据其各自级别拥有的相应功能,可以执行相对应的操作,具体如图1-4所示:

图1-4 系统用例设计图

第2章 系统设计

2.1 系统的功能结构图

根据三个用户的操作需求,将系统划分为如下三大功能,并对其模块的划分和功能进行描述。

  • 管理员功能
    登录:登录
    学生管理:列表、添加、修改、删除
    班级管理:列表、添加、修改、删除
    课程管理:列表、添加、修改、删除
    教师管理:列表、添加、修改、删除
    系统用户:添加、删除
    密码:修改
  • 学生功能
    登录:登录
    选课管理:选课、打印
    退课管理:退课
    成绩:查看、打印
    个人信息:查看
    密码:修改
  • 教师功能

登录:登录

授课信息:查看

成绩管理:编辑成绩

学生信息:查看

班级信息:查看

个人信息:查看

密码:修改

综上,整个系统的功能结构图如图2-1所示:

图2-1系统功能结构图

2.2 数据库的设计

2.2.1 概念模型设计

系统的实体关系模型:管理员管理学生、教师、班级、课程、系统用户,管理员和学生、教师、班级、课程、系统用户是一对多的关系,教师和课程是一对多的关系,学生与课程是多对多的关系。具体如图2-2所示:

图2-2 系统E-R图

2.2.2 逻辑模型设计

根据图2-1的系统E-R图进行逻辑结构设计,结果如下所述:

  1. 管理员(管理员id,用户名,密码,身份)
  2. 学生(学生id,用户名,密码,学号,职务,姓名,性别,出生日期,宿舍号,身份证号,民族,籍贯,政治面貌,家庭住址,联系电话,电子邮箱,身份)
  3. 教师(教师id,用户名,密码,教师号,姓名,性别,出生日期,教师职称,专业,家庭住址,联系电话,电子邮箱,身份)
  4. 课程(课程id,课程名,授课教师,总课时,上课时间,上课地点)
  5. 选课(学生id课程id,成绩)
  6. 班级(班级id,班级名称,班主任,人数)

2.2.3 物理模型设计

根据系统的需求,经过详细的分析设计,本系统数据库中各个数据表的字段定义如下:

  1. 管理员表admin用来存储管理员的账户信息,表的设计如表2-1所示。
    表2-1 admin

字段描述

数据类型

允许为空

主键/外键

id

Int


name

Varchar

主键

pwd

Varchar


shenfen

Varchar


  1. 班级表banji用来存储班级的信息,表的设计如表2-2所示。
    表2-2 banji

字段描述

数据类型

允许为空

主键/外键

id

Int

主键

name

Varchar


banzhuren

Varchar


renshu

Varchar


shuoming

Text


  1. 成绩表chengji用来存储学生的课程成绩,表的设计如表2-3所示。
    表2-3 chengji

字段描述

数据类型

允许为空

主键/外键

id

Int

主键

xuesheng

Int

外键

kemu

varchar

外键

fenshu

varchar


  1. 成绩表jiaoshi用来存储老师的基本信息,表的设计如表2-4所示。
    表2-4 jiaoshi

字段描述

数据类型

允许为空

主键/外键

id

Int


name

Varchar

主键

pwd

Varcgar


jiaoshihao

Varchar


zhenname

Varchar


sex

Varchar


shengri

Varchar


zhicheng

Varchar


zhuanye

Varchar


phone

Varchar


address

Varchar


email

Varchar


shenfen

Varchar


  1. 课程表kecheng用来存储开设的课程信息,表的设计如表2-5所示。
    表2-5 kecheng

字段描述

数据类型

允许为空

主键/外键

id

Int


name

Varchar

主键

jiaoshi

Varchar

外键

keshi

Varchar


beizhu

Text


  1. 课程安排表kechengtable用来存储课程的课程安排信息,表的设计如表2-6所示。
    表2-6 kechengtable

字段描述

数据类型

允许为空

主键/外键

id

Int

主键

kecheng

Int


didian

Varchar


xingqi

Varchar


shangxiawu

Varchar


kejie

Varchar


beizhu

Text


  1. 选课表xuanke用来存储学生的选课信息,表的设计如表2-7所示。
    表2-7 xuanke

字段描述

数据类型

允许为空

主键/外键

id

Int

主键

xuesheng

Int

外键

kecheng

Int

外键

  1. 学生表xuesheng用来存储学生的基本信息,表的设计如表2-8所示。

表2-8 xuesheng

字段描述

数据类型

允许为空

主键/外键

id

Int


name

Varchar

主键

pwd

Varchar


banji

Varchar


xuehao

Varchar


zhiwu

String


zhenname

Varchar


sex

Varchar


sushehao

Varchar


shenfenzheng

Varchar


minzu

Varchar


jiguan

Varchar


zhengzhi

Varchar


address

Varchar


phone

Varchar


email

Varchar


beizhu

Text


shenfen

Varchar


第3章 系统实现

3.1 实现环境

本系统采用MyEclipse10开发工具,运行环境为jdk1.6,服务器tomcat5.5以上,利用MySQL数据库来创建数据库,并实现信息管理。

3.2 开发框架

本系统是一个教务管理系统,该系统采用结构化的系统分析方法,采用MVC框架,结合JSP+servlet+JavaBean技术进行开发。

3.3主要功能3-5个的开发流程

3.3.1 课程管理功能

管理员点击课程管理后,会显示所有已添加的课程,可以新增课程,还能对已有课程添加课程安排并且修改和删除信息等,界面如图3-1所示。

图3-1 课程管理界面

主要代码如下:

<%

ArrayList client = array.getKecheng();

Validate v = new Validate();

String guanjian = v.getUnicode(request.getParameter("guanjian"));

if(guanjian != null && !guanjian.equals("")){

client = array.getKechengcha(guanjian);}

for(int i = 0;i < client.size();i++){

ArrayList alRow = (ArrayList)client.get(i);

ArrayList jiaoshi = array.getLaoshi(alRow.get(2).toString());

%>

点击添加课程,管理员输入课程名称、选择系统中存在的教师以及总课时,点击提交及添加成功,如图3-2所示。

图3-2 添加课程界面

主要代码如下:

String mark = request.getParameter("mark");

String id = request.getParameter("id");

String kechengid = request.getParameter("kechengid");

ArrayList client = array.getKechengtable(id);

ArrayList kecheng = array.getKecheng(kechengid);

String str = "";

if(mark != null && mark.equals("add")){

str = "添加";

}

if(mark != null && mark.equals("update")){

str = "修改";

}

添加课程后,点击课程安排,可以查看本门课程的授课教师、时间和地点,同时也可以进行增加修改和删除。如图3-3所示。

图3-3 课程安排界面

主要代码如下:

<%

for(int i = 0;i < client.size();i++){

ArrayList alRow = (ArrayList)client.get(i);

%>

<tr class="tabletd<%=i%2+1 %>">

<td height="25" align="center"><%=i+1 %></td>

<td height="25" align="center"><%=alRow.get(2) %></td>

<td ><%=alRow.get(3)+""+alRow.get(4)+""+alRow.get(5) %></td>

<td height="25" align="center"><%=alRow.get(6) %></td>

<td >

<a href="<%=path %>/admin/kechengtable.jsp?mark=update&id=<%=alRow.get(0) %>

&kechengid=<%=kechengid %>">修改</a>

<a href="<%=path %>/DelServlet?kechengtable=<%=alRow.get(0) %>&kechengid=<

%=kechengid %>">删除</a></td>

</tr>

<%} %>

<tr class="tabletop">

<td height="25" colspan="12" align="center">

<a href="<%=path %>/admin/kechengtable.jsp?mark=add&kechengid=<%=kechengid

%>">添加课程安排</a></td></tr>

3.3.2 选课管理功能

学生进入系统后,点击选课管理后,会显示所有可选可退的课程,点击课程名称可以查看授课教师,点击课程表可以查看课程安排。界面如图3-4所示。

图3-4 选课管理界面

主要代码如下:

<%

ArrayList client = array.getXuanke("",adminlogin.get(0).toString());

Validate v = new Validate();

String guanjian = v.getUnicode(request.getParameter("guanjian"));

if(guanjian != null && !guanjian.equals("")){

client = array.getXuanke("and name like

'%"+guanjian+"%'",adminlogin.get(0).toString());

}

for(int i = 0;i < client.size();i++){

ArrayList alRow = (ArrayList)client.get(i);

ArrayList jiaoshi = array.getLaoshi(alRow.get(2).toString());

%>

学生点击自己想选的课程,即会弹出选课成功提示。界面如图3-5所示。

图3-5 选课成功界面

主要代码如下:

response.setContentType("text/html;charset=gb2312");

request.setCharacterEncoding("gb2312");

String id = request.getParameter("id");

HttpSession session = request.getSession();

ArrayList adminlogin = (ArrayList)session.getAttribute("adminlogin");

ArrayList xuesheng = (ArrayList)session.getAttribute("xuesheng.banji");

InsertUpdateDelBean ib = new InsertUpdateDelBean();

String sql = "insert into xuanke(xuesheng,kecheng)

values("+adminlogin.get(0)+","+id+")";

String sql2 = "insert into chengji(xuesheng,kemu,fenshu)

values("+adminlogin.get(0)+","+id+",0)";

ib.insertANDupdateANDdel(sql);

ib.insertANDupdateANDdel(sql2);

request.setAttribute("message", "选课成功");

学生如果选错了的课程,可以点击退课,即会弹出退课成功提示。界面如图3-6所示。

图3-6 退课成功界面

主要代码如下:

if(tuike != null && !tuike.equals("")){

str = "/xuesheng/kecheng_list.jsp";

sql = "delete from xuanke where id="+tuike;

ib.insertANDupdateANDdel(sql);

sql = "delete from chengji where id="+tuike;

ib.insertANDupdateANDdel(sql);

request.setAttribute("message", "退课成功!");

}

3.3.3 成绩管理功能

教师进入系统后,点击成绩管理,会显示所有教授的课程,点击课程名称可以查看授课信息。界面如图3-7所示。

图3-7 成绩管理界面

主要代码如下:

if(tuike != null && !tuike.equals("")){

str = "/xuesheng/kecheng_list.jsp";

sql = "delete from xuanke where id="+tuike;

ib.insertANDupdateANDdel(sql);

sql = "delete from chengji where id="+tuike;

ib.insertANDupdateANDdel(sql);

request.setAttribute("message", "退课成功!");

}

教师点击添加成绩可以显示所有选择了该门课程的学生的成绩。界面如图3-8所示。

图3-8 显示成绩界面

主要代码如下:

<%

ArrayList client = array.getLkechengcha(adminlogin.get(0).toString());

for(int i = 0;i < client.size();i++){

ArrayList alRow = (ArrayList)client.get(i);

%>

<tr class="tabletd<%=i%2+1 %>">

<td height="25" align="center"><%=i+1 %></td>

<td><a title="点击查看详细信息"

href="<%=path %>/jiaoshi/kecheng_show.jsp?id=<%=alRow.get(0) %>">

<%=alRow.get(1) %></a></td>

<td height="25" align="center">

<a href="<%=path %>/jiaoshi/addchengji.jsp?kemuid=<%=alRow.get(0) %>">

添加成绩</a></td>

</tr>

<%} %>

点击编辑,可以编辑学生本门课程的成绩。界面如图3-9所示。

图3-9 编辑成绩界面

主要代码如下:

<%

ArrayList xuesheng = array.getXuesheng(client.get(1).toString());

%>

<tr>

<td height="25" align="right" class="tabletd1">学生姓名:</td>

<td height="25" class="tabletd1"> <%=xuesheng.get(6) %></td>

</tr>

<tr>

<td height="25" align="right" class="tabletd2">分数:</td>

<td height="25" class="tabletd2"> <input type="text" name="fenshu" value="<%=client.get(3) %>"></td>

</tr>

<tr>

<td height="30" colspan="2" align="center" class="tabletd1"><input type="submit" value="提交" class="input"></td>

</tr>

第4章 总结

在完成教务管理系统这个项目时,我首先根据自己的了解对系统进行需求分析,然后在网上查阅资料,最终决定将系统角色主要划分为三个角色:管理员、学生和教师;然后根据三个角色的不同需求来设计数据表;最后根据前面的工作划分系统功能模块,例如课程管理模块、学生管理模块、教师管理模块、班级管理模块、成绩管理模块、选课管理模块等。

在完成上述工作后,经过开发编写程序,整个教务管理系统的功能基本实现。其中,主要实现的功能模块分为三大块:管理员可以对学生、教师、班级、课程和系统用户进行管理,同时还可以修改密码;学生可以选课、退课、查看个人信息和查看打印成绩,同时可以修改个人密码;教师可以查看授课信息、查看自己所带班级信息和给出所授课程的课程成绩,同时可以修改个人密码。

教务管理系统中的部分功能由于个人水平和时间问题,还可以继续改进和完善:如管理员添加课程时可以直接将课程选给整个班级学生;学生选课和退课时可以增加限制条件;教师在添加成绩时可以给整个班级添加成绩等。

相关推荐

网站建设:从新手到高手

现代化网站应用领域非常广泛,从个人形象网站展示、企业商业网站运作、到政府公益等服务网站,各行各业都需要网站建设。大体上可以归结四类:宣传型网站设计、产品型网站制作、电子商务型网站建设、定制型功能网站开...

JetBrains 推出全新 AI 编程工具 Junie,助力高效开发

JetBrains宣布推出名为Junie的全新AI编程工具。这款工具不仅能执行简单的代码生成与检查任务,还能应对编写测试、验证结果等复杂项目,为开发者提供全方位支持。根据SWEBench...

AI也能写代码!代码生成、代码补全、注释生成、代码翻译轻松搞定

清华GLM技术团队打造的多语言代码生成模型CodeGeeX近期更新了新的开源版本「CodeGeeX2-6B」。CodeGeeX2是多语言代码生成模型CodeGeeX的第二代模型,不同于一代CodeG...

一键生成前后端代码,一个36k星的企业级低代码平台

「企业级低代码平台」前后端分离架构SpringBoot2.x,SpringCloud,AntDesign&Vue,Mybatis,Shiro,JWT。强大的代码生成器让前后端代码一键生成,无需写任...

Gitee 代码托管实战指南:5 步完成本地项目云端同步(附避坑要点)

核心流程拆解:远程仓库的搭建登录Gitee官网(注册账号比较简单,大家自行操作),点击“新建仓库”,建议勾选“初始化仓库”和“设置模板文件”(如.gitignore),避免上传临时文件。...

jeecg-boot 源码项目-强烈推荐使用

JEECGBOOT低代码开发平台...

JetBrains推出全新AI编程工具Junie,强调以开发者为中心

IT之家2月1日消息,JetBrains发文,宣布推出一款名为Junie的全新AI编程工具,官方声称这款AI工具既能执行简单的代码生成与检查等基础任务,也能应对“编写测试、验证结...

JetBrains旗下WebStorm和Rider现已加入“非商用免费”阵营

IT之家10月25日消息,软件开发商JetBrains今日宣布,旗下WebStorm(JavaScript开发工具)和Rider(.NET开发工具)现已加入“非商用免费”阵营。如果...

谈谈websocket跨域

了解websocketwebsocket是HTML5的新特性,在客户端和服务端提供了一个基于TCP连接的双向通道。...

websocket调试工具

...

利用webSocket实现消息的实时推送

1.什么是webSocketwebSocket实现实现推送消息WebSocket是HTML5开始提供的一种在单个TCP连接上进行全双工通讯的协议。以前的推送技术使用Ajax轮询,浏览器需...

Flutter UI自动化测试技术方案选型与探索

...

为 Go 开发的 WebSocket 库

#记录我的2024#...

「Java基础」Springboot+Websocket的实现后端数据实时推送

这篇文章主要就是实现这个功能,只演示一个基本的案例。使用的是websocket技术。...

【Spring Boot】WebSocket 的 6 种集成方式

介绍...

取消回复欢迎 发表评论: