java实践设计——教务管理系统 内包含源码+sql+项目报告
最近更新 2024年06月18日
资源编号 160

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

郑重承诺丨云炬网络提供安全交易、信息保真!
云炬公益:平台收入的50%以上将进行公益慈善捐赠(不定期公示):
¥ 9.9云朵

VIP 5折、云炬VIP年会员免费升级VIP

升级VIP实现财富自由和身心具足
立即下载 查看演示 升级会员 云炬学堂 升级会员
详情介绍

《教务管理系统》

项目报告

题 目: 教务管理系统


目 录

第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个基本流程。

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

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

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

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

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

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

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

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

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

1.3 用例图

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

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

图1-4 系统用例设计图

第2章 系统设计

2.1 系统的功能结构图

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

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

登录:登录

授课信息:查看

成绩管理:编辑成绩

学生信息:查看

班级信息:查看

个人信息:查看

密码:修改

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

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

图2-1系统功能结构图

2.2 数据库的设计

2.2.1 概念模型设计

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

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

图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所示。

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

图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所示。

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

图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所示。

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

图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>&nbsp;&nbsp;

<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所示。

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

图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所示。

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

图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所示。

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

图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所示。

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

图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所示。

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

图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) %>" rel="external nofollow" >

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

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

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

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

</tr>

<%} %>

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

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

图3-9 编辑成绩界面

主要代码如下:

<%

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

%>

<tr>

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

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

</tr>

<tr>

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

<td height="25" class="tabletd2">&nbsp;<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章 总结

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

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

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

 

 

 

资源下载此资源下载价格为9.9云朵立即购买,VIP 5折、云炬VIP年会员免费
客服微信:2743319061
收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章资源,如无特殊说明或标注,均为本站网友和创作者贡献分享。如若本站内容侵犯了原著者的合法权益,可联系网站客服QQ2743319061删除。

云炬星球 课设源码 java实践设计——教务管理系统 内包含源码+sql+项目报告 https://src.yunjunet.cn/160.html

常见问题
  • 放心亲,我们不会为了几十块钱的东西坏了名声!
查看详情
  • 方法一:点击“立即下载.”按钮,付款后在下载弹窗的虚线框的隐藏信息里获取 方法二:在正文底部使用VIP查看隐藏的解压密码 方法三:联系【云炬网络】公众号客服获取
查看详情
  • 付款后会出现“立即下载”按钮(点击即可下载),如果下载失败也可以联系客服发订单截图补发。
查看详情
  • 登录购买会多端同步购买记录,永久可以查看反复下载;非登录购买仅将购买记录保存到本地浏览器中,浏览器cookie清除后无法再次下载。先右上角点登录,然后点击微信图标可以快速授权注册登录^_^
查看详情
  • 可以试看。点击”查看演示“或“试看预览”按钮可以试读从资料目录中节选的部分内容,也可以自己指定想试看的内容。
查看详情
  • 原因一:本站所有资源已开启有效性检测(服务器24h全自动监测),当监测到下载链接无法访问时会提示“该资源已失效,请勿购买”,遇到这种情况可以联系客服修复失效的下载链接,或直接联系客服在淘宝下单购买即可。(检测原理:购买前服务器程序会预访问下载链接,响应值为200说明资源有效允许购买,响应值为404或502等报错说明资源失效禁止购买)。原因二:上传者未启用“下载”选项。
查看详情
官方客服团队

为您解决烦忧 - 24小时在线 专业服务