每天记录学习,每天会有好心情。*^_^*

今天将为大家分析一个基于web的教学进度管理平台,本文设计的高校教学管理系统能够完成教学计划制定,自动排课,课程管理,教学资源管理,学生管理等多方面的功能。采用当前非常流行的B/S体系结构,以JAVA作为开发技术,主要依赖SSM技术框架,mysql数据库建立本系统。基于web的教学进度管理平台项目使用框架为SSM(MYECLIPSE),选用开发工具为MYECLIPSE。基于web的教学进度管理平台为一个 后台项目。
为了完成基于web的教学进度管理平台,我们首先需要对该系统进行需求分析。一个基于web的教学进度管理平台应包含用户角色有管理员、学生。为了能让用户顺利登陆系统完成相关操作,需要为每种登陆角色设置账户和密码字段。
系统中学生、考勤之间具有较强的联系性。他们之间的关系为考勤的学生与学生的mingzi字段对应、考勤的学生id与学生的id字段对应
。在考勤表中可以体现出这种关系。

总结得出基于web的教学进度管理平台项目所有数据为:管理员(admin)、考勤(kaoqing)、学生(xuesheng)、课程(kecheng)

基于web的教学进度管理平台之管理员表

字段名 | 类型 | 属性 | 描述
id | INT(11) | PRIMARY KEY | 管理员id
username | VARCHAR(255) | | 账号
password | VARCHAR(255) | | 密码

基于web的教学进度管理平台之考勤表

字段名 | 类型 | 属性 | 描述
id | INT(11) | PRIMARY KEY | 考勤id
xuesheng | VARCHAR(255) | | 学生
xueshengid | VARCHAR(255) | | 学生id
kecheng | VARCHAR(255) | | 课程
shijian | VARCHAR(255) | | 时间
renkelaoshi | VARCHAR(255) | | 任课老师

基于web的教学进度管理平台之学生表

字段名 | 类型 | 属性 | 描述
id | INT(11) | PRIMARY KEY | 学生id
username | VARCHAR(255) | | 账号
password | VARCHAR(255) | | 密码
xuehao | VARCHAR(255) | | 学号
mingzi | VARCHAR(255) | | 名字
banji | VARCHAR(255) | | 班级

基于web的教学进度管理平台之课程表

字段名 | 类型 | 属性 | 描述
id | INT(11) | PRIMARY KEY | 课程id
biaoti | VARCHAR(255) | | 标题
neirong | VARCHAR(255) | | 内容
renkelaoshi | VARCHAR(255) | | 任课老师
shangkeshijian | VARCHAR(255) | | 上课时间
SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------

-- ----------------------------

-- Table structure for ggjywebdjxjdglpt

-- ----------------------------

DROP TABLE IF EXISTS `t_admin`;

CREATE TABLE `t_admin` (`id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '管理员id',`username` VARCHAR(255) DEFAULT NULL COMMENT '账号',`password` VARCHAR(255) DEFAULT NULL COMMENT '密码',PRIMARY KEY (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='管理员';

-- ----------------------------

DROP TABLE IF EXISTS `t_kaoqing`;

CREATE TABLE `t_kaoqing` (`id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '考勤id',`xuesheng` VARCHAR(255) DEFAULT NULL COMMENT '学生',`xueshengid` INT(11) DEFAULT NULL COMMENT '学生id',`kecheng` VARCHAR(255) DEFAULT NULL COMMENT '课程',`shijian` VARCHAR(255) DEFAULT NULL COMMENT '时间',`renkelaoshi` VARCHAR(255) DEFAULT NULL COMMENT '任课老师',PRIMARY KEY (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='考勤';

-- ----------------------------

DROP TABLE IF EXISTS `t_xuesheng`;

CREATE TABLE `t_xuesheng` (`id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '学生id',`username` VARCHAR(255) DEFAULT NULL COMMENT '账号',`password` VARCHAR(255) DEFAULT NULL COMMENT '密码',`xuehao` VARCHAR(255) DEFAULT NULL COMMENT '学号',`mingzi` VARCHAR(255) DEFAULT NULL COMMENT '名字',`banji` VARCHAR(255) DEFAULT NULL COMMENT '班级',PRIMARY KEY (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='学生';

-- ----------------------------

DROP TABLE IF EXISTS `t_kecheng`;

CREATE TABLE `t_kecheng` (`id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '课程id',`biaoti` VARCHAR(255) DEFAULT NULL COMMENT '标题',`neirong` VARCHAR(255) DEFAULT NULL COMMENT '内容',`renkelaoshi` VARCHAR(255) DEFAULT NULL COMMENT '任课老师',`shangkeshijian` VARCHAR(255) DEFAULT NULL COMMENT '上课时间',PRIMARY KEY (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='课程';

添加考勤模块:

在kaoqingController中定义tianjiakaoqingact接收页面传入的考勤参数,定义为kaoqing。其中kaoqing包含字段:学生,学生id,课程,时间,任课老师,使用tianjiakaoqingact将该考勤对象存入数据库中,在kaoqingMapper中定义了insert方法,匹配数据库中的insert into kaoqing语句实现将考勤数据存入数据库的操作。该部分核心代码如下:

通过kaoqingdao的insert方法将页面传输的考勤添加到数据库中 kaoqingdao.insert(kaoqing);

将添加考勤成功信息,保存到request的message中,在页面中给出用户提示 request.setAttribute("message", "添加考勤成功");

返回考勤管理界面

return "forward:/tianjiakaoqing.action";

查询考勤模块:

在浏览器中进入考勤查询页面时,此时浏览器的地址栏为kaoqingguanli.action,该地址将响应kaoqingController类中的kaoqingguanli,在该方法中,通过selectByexample方法获取所有的考勤信息,并将该信息保存到request中,在页面进行循环展示。该部分核心代码如下:

生成考勤样例类,通过example定义查询条件 KaoqingExample example = new KaoqingExample();

通过kaoqingdao的selectByExample方法查询出所有的考勤信息 List kaoqingall = kaoqingdao.selectByExample(example);

将考勤信息,保存到request中,在页面通过foreach方法进行展示 request.setAttribute("kaoqingall", kaoqingall);

返回考勤管理界面

return "forward:/kaoqingguanli.action";

修改考勤模块:

点击修改按钮,可以跳转到考勤修改页面。在考勤修改页面中,将初始化该考勤的所有信息,并将信息一一对应填充到对应编辑栏中。编辑完考勤信息后,页面通过post方法将数据封装为一个考勤实体,传入到kaoqingController中。在xiugaikaoqing中进行接收,接收完毕后,调用kaoqingMapper中的updateByPrimaryKeySelective方法进行修改。该部分代码如下:

通过kaoqingdao的修改方法根据id修改对应的考勤 kaoqingdao.updateByPrimaryKeySelective(kaoqing);

将修改考勤成功信息,保存到request的message中,在页面中给出用户提示 request.setAttribute("message", "修改考勤信息成功");

返回考勤管理界面

return "forward:/kaoqingguanli.action";

删除考勤模块:

在管理页面中,点击删除。页面将通过a标签的href属性,使用get方法将该考勤

的id上传到服务器中,在服务器中通过kaoqingController类中的shanchukaoqing进行接收,之后调用kaoqingMapper中的deleteByPrimaryKey方法根据ID进行删除。将删除信息保存到request的message中,在页面给出用户删除成功的提示信息,该部分核心代码如下:

通过kaoqingdao的删除方法根据id删除对应的考勤 kaoqingdao.deleteByPrimaryKey(id);

将删除考勤成功信息,保存到request的message中,在页面中给出用户提示 request.setAttribute("message", "删除考勤成功");

返回考勤管理界面

return "forward:/kaoqingguanli.action";

源码下载

02-10 02:49