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

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

yuyutoo 2024-10-12 00:40 2 浏览 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章 总结

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

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

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

相关推荐

jQuery VS AngularJS 你更钟爱哪个?

在这一次的Web开发教程中,我会尽力解答有关于jQuery和AngularJS的两个非常常见的问题,即jQuery和AngularJS之间的区别是什么?也就是说jQueryVSAngularJS?...

Jquery实时校验,指定长度的「负小数」,小数位未满末尾补0

在可以输入【负小数】的输入框获取到焦点时,移除千位分隔符,在输入数据时,实时校验输入内容是否正确,失去焦点后,添加千位分隔符格式化数字。同时小数位未满时末尾补0。HTML代码...

如何在pbootCMS前台调用自定义表单?pbootCMS自定义调用代码示例

要在pbootCMS前台调用自定义表单,您需要在后台创建表单并为其添加字段,然后在前台模板文件中添加相关代码,如提交按钮和表单验证代码。您还可以自定义表单数据的存储位置、添加文件上传字段、日期选择器、...

编程技巧:Jquery实时验证,指定长度的「负小数」

为了保障【负小数】的正确性,做成了通过Jquery,在用户端,实时验证指定长度的【负小数】的方法。HTML代码<inputtype="text"class="forc...

一篇文章带你用jquery mobile设计颜色拾取器

【一、项目背景】现实生活中,我们经常会遇到配色的问题,这个时候去百度一下RGB表。而RGB表只提供相对于的颜色的RGB值而没有可以验证的模块。我们可以通过jquerymobile去设计颜色的拾取器...

编程技巧:Jquery实时验证,指定长度的「正小数」

为了保障【正小数】的正确性,做成了通过Jquery,在用户端,实时验证指定长度的【正小数】的方法。HTML做成方法<inputtype="text"class="fo...

jquery.validate检查数组全部验证

问题:html中有多个name[],每个参数都要进行验证是否为空,这个时候直接用required:true话,不能全部验证,只要这个数组中有一个有值就可以通过的。解决方法使用addmethod...

Vue进阶(幺叁肆):npm查看包版本信息

第一种方式npmviewjqueryversions这种方式可以查看npm服务器上所有的...

layui中使用lay-verify进行条件校验

一、layui的校验很简单,主要有以下步骤:1.在form表单内加上class="layui-form"2.在提交按钮上加上lay-submit3.在想要校验的标签,加上lay-...

jQuery是什么?如何使用? jquery是什么功能组件

jQuery于2006年1月由JohnResig在BarCampNYC首次发布。它目前由TimmyWilson领导,并由一组开发人员维护。jQuery是一个JavaScript库,它简化了客户...

django框架的表单form的理解和用法-9

表单呈现...

jquery对上传文件的检测判断 jquery实现文件上传

总体思路:在前端使用jquery对上传文件做部分初步的判断,验证通过的文件利用ajaxFileUpload上传到服务器端,并将文件的存储路径保存到数据库。<asp:FileUploadI...

Nodejs之MEAN栈开发(四)-- form验证及图片上传

这一节增加推荐图书的提交和删除功能,来学习node的form提交以及node的图片上传功能。开始之前需要源码同学可以先在git上fork:https://github.com/stoneniqiu/R...

大数据开发基础之JAVA jquery 大数据java实战

上一篇我们讲解了JAVAscript的基础知识、特点及基本语法以及组成及基本用途,本期就给大家带来了JAVAweb的第二个知识点jquery,大数据开发基础之JAVAjquery,这是本篇文章的主要...

推荐四个开源的jQuery可视化表单设计器

jquery开源在线表单拖拉设计器formBuilder(推荐)jQueryformBuilder是一个开源的WEB在线html表单设计器,开发人员可以通过拖拉实现一个可视化的表单。支持表单常用控件...

取消回复欢迎 发表评论: