员工绩效考核|基于Springboot的员工绩效考核管理系统设计与实现(源码+数据库+文档)
员工绩效考核管理系统目录基于Springboot的员工绩效考核管理系统设计与实现一、前言二、系统功能设计三、系统实现4.1.1系统登录模块实现4.1.2个人中心管理功能模块实现4.1.3部门信息管理模块实现4.1.4部门信息管理模块实现4.1.5绩效指标管理模块实现4.1.6公告信息管理模块的实现4.1.7岗位管理模块的实现4.1.8绩效考核管理模块的实现四、数据库设计1、实体ER图五、核心代码六、论文参考七、最新计算机毕设选题推荐八、源码获取博主介绍✌️大厂码农|毕设布道师阿里云开发社区乘风者计划专家博主CSDN平台Java领域优质创作者专注于大学生项目实战开发、讲解和毕业答疑辅导。✌️主要项目小程序、SpringBoot、SSM、Vue、Html、Jsp、Nodejs等设计与开发。文末获取源码联系基于Springboot的员工绩效考核管理系统设计与实现一、前言基于javaweb的员工绩效考核系统本系统为员工绩效考核管理系统助企业衡量和提升员工绩效基于Spring Boot的企业员工绩效考核管理系统本月度员工绩效考核管理系统采用java语言做为代码编写工具,本系统为月度员工绩效考核管理系统绩效考核管理系统的产生,是专为企业开发的对员工考核的协助软件。可以帮助企业对于员工的绩效考核进行更为正规、规范的管理使企业管理更加的轻松快捷本月度员工绩效考核管理系统采用java语言做为代码编写工具采用mysql数据库进行系统中信息的存储与处理。框架采用springboot。本月度员工绩效考核管理系统调试环境为myeclipse服务器为tomcat。主要包括的内容有部门方面、员工方面、绩效考核方面、绩效指标方面。员工可以查询绩效指标和绩效考核详情管理员进行发布和管理。本系统结合了新时代的工作要求和获得了先进技术的支持适应时代发展为使用人员提供了极好的绩效考核途径。关键词部门管理绩效指标管理绩效考核管理springboot框架二、系统功能设计根据系统分析中分析出来的功能本系统的主要功能包括部门管理、岗位管理、绩效指标管理、绩效考核管理、员工管理、通知管理等。本系统的功能结构设计如下图3.1所示三、系统实现4.1.1系统登录模块实现本模块界面加入了系统标题和角色的选择在本界面中采用了图形和控件进行合理摆放的方法进行设计还加入了合适的背景图片使登录界面更加的直观。系统登录模块设计实现界面如下图4.1所示图4.1系统登录模块界面实现4.1.2个人中心管理功能模块实现本界面主要是对管理员账号和密码进行设置是管理员角色的操作功能员工不能添加管理员账号个人中心管理功能实现界面如下图4.2所示图4.2个人中心管理模块实现界面4.1.3部门信息管理模块实现部门信息是管理员角色的功能管理员可以为企业添加新的部门可以查询部门的创建时间管理员添加部门信息的实现界面如下图4.3所示图4.3管理员添加部门信息实现界面管理员添加部门信息的流程为先进行必要字段的填写数据库进行判定是否合法、是否为空然后进行数据库信息的插入。4.1.4部门信息管理模块实现管理员可以在新员工招入时进行添加对员工进行部门的安排和备注的添加。管理员添加员工信息的界面实现如下图4.4所示图4.4管理员添加员工信息界面实现4.1.5绩效指标管理模块实现本功能是为了方便管理员对员工进行绩效考核添加绩效指标的实现界面如下图4.5所示图4.5添加绩效指标模块的界面实现4.1.6公告信息管理模块的实现本功能可以实现公告的发布添加公告信息功能模块的实现界面如下图4.6所示图4.6添加公告模块的实现界面4.1.7岗位管理模块的实现管理员可以对员工分配岗位管理员查询岗位的实现界面如下图4.7所示图4.7查询岗位信息的实现界面4.1.8绩效考核管理模块的实现发布员工的绩效考核绩效考核信息的实现界面如下图4.8所示图4.8绩效考核信息界面4.2员工功能的界面实现员工可以查询公告和绩效指标、绩效考核信息也可以修改个人资料和密码。实现界面如下图4.9所示图4.9员工功能的实现界面四、数据库设计1、实体ER图1管理员实体的Er图如下图3.2所示图3.2管理员Er图2管理员管理的员工信息ER图如图3.3所示。图3.3员工信息ER图3企业中部门信息ER图如图3.4所示图3.4部门信息ER图五、核心代码package com.controller; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Arrays; import java.util.Calendar; import java.util.Map; import java.util.HashMap; import java.util.Iterator; import java.util.Date; import java.util.List; import javax.servlet.http.HttpServletRequest; import com.utils.ValidatorUtils; import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.format.annotation.DateTimeFormat; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.baomidou.mybatisplus.mapper.Wrapper; import com.annotation.IgnoreAuth; import com.entity.BumenEntity; import com.entity.view.BumenView; import com.service.BumenService; import com.service.TokenService; import com.utils.PageUtils; import com.utils.R; import com.utils.MD5Util; import com.utils.MPUtil; import com.utils.CommonUtil; /** * 部门 * 后端接口 * author * email * date 2021-05-07 10:42:31 */ RestController RequestMapping(/bumen) public class BumenController { Autowired private BumenService bumenService; /** * 后端列表 */ RequestMapping(/page) public R page(RequestParam MapString, Object params,BumenEntity bumen, HttpServletRequest request){ EntityWrapperBumenEntity ew new EntityWrapperBumenEntity(); PageUtils page bumenService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, bumen), params), params)); return R.ok().put(data, page); } /** * 前端列表 */ RequestMapping(/list) public R list(RequestParam MapString, Object params,BumenEntity bumen, HttpServletRequest request){ EntityWrapperBumenEntity ew new EntityWrapperBumenEntity(); PageUtils page bumenService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, bumen), params), params)); return R.ok().put(data, page); } /** * 列表 */ RequestMapping(/lists) public R list( BumenEntity bumen){ EntityWrapperBumenEntity ew new EntityWrapperBumenEntity(); ew.allEq(MPUtil.allEQMapPre( bumen, bumen)); return R.ok().put(data, bumenService.selectListView(ew)); } /** * 查询 */ RequestMapping(/query) public R query(BumenEntity bumen){ EntityWrapper BumenEntity ew new EntityWrapper BumenEntity(); ew.allEq(MPUtil.allEQMapPre( bumen, bumen)); BumenView bumenView bumenService.selectView(ew); return R.ok(查询部门成功).put(data, bumenView); } /** * 后端详情 */ RequestMapping(/info/{id}) public R info(PathVariable(id) Long id){ BumenEntity bumen bumenService.selectById(id); return R.ok().put(data, bumen); } /** * 前端详情 */ RequestMapping(/detail/{id}) public R detail(PathVariable(id) Long id){ BumenEntity bumen bumenService.selectById(id); return R.ok().put(data, bumen); } /** * 后端保存 */ RequestMapping(/save) public R save(RequestBody BumenEntity bumen, HttpServletRequest request){ bumen.setId(new Date().getTime()new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(bumen); bumenService.insert(bumen); return R.ok(); } /** * 前端保存 */ RequestMapping(/add) public R add(RequestBody BumenEntity bumen, HttpServletRequest request){ bumen.setId(new Date().getTime()new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(bumen); bumenService.insert(bumen); return R.ok(); } /** * 修改 */ RequestMapping(/update) public R update(RequestBody BumenEntity bumen, HttpServletRequest request){ //ValidatorUtils.validateEntity(bumen); bumenService.updateById(bumen);//全部更新 return R.ok(); } /** * 删除 */ RequestMapping(/delete) public R delete(RequestBody Long[] ids){ bumenService.deleteBatchIds(Arrays.asList(ids)); return R.ok(); } /** * 提醒接口 */ RequestMapping(/remind/{columnName}/{type}) public R remindCount(PathVariable(columnName) String columnName, HttpServletRequest request, PathVariable(type) String type,RequestParam MapString, Object map) { map.put(column, columnName); map.put(type, type); if(type.equals(2)) { SimpleDateFormat sdf new SimpleDateFormat(yyyy-MM-dd); Calendar c Calendar.getInstance(); Date remindStartDate null; Date remindEndDate null; if(map.get(remindstart)!null) { Integer remindStart Integer.parseInt(map.get(remindstart).toString()); c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindStart); remindStartDate c.getTime(); map.put(remindstart, sdf.format(remindStartDate)); } if(map.get(remindend)!null) { Integer remindEnd Integer.parseInt(map.get(remindend).toString()); c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindEnd); remindEndDate c.getTime(); map.put(remindend, sdf.format(remindEndDate)); } } WrapperBumenEntity wrapper new EntityWrapperBumenEntity(); if(map.get(remindstart)!null) { wrapper.ge(columnName, map.get(remindstart)); } if(map.get(remindend)!null) { wrapper.le(columnName, map.get(remindend)); } int count bumenService.selectCount(wrapper); return R.ok().put(count, count); } } package com.controller; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Arrays; import java.util.Calendar; import java.util.Map; import java.util.HashMap; import java.util.Iterator; import java.util.Date; import java.util.List; import javax.servlet.http.HttpServletRequest; import com.utils.ValidatorUtils; import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.format.annotation.DateTimeFormat; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.baomidou.mybatisplus.mapper.Wrapper; import com.annotation.IgnoreAuth; import com.entity.GangweiEntity; import com.entity.view.GangweiView; import com.service.GangweiService; import com.service.TokenService; import com.utils.PageUtils; import com.utils.R; import com.utils.MD5Util; import com.utils.MPUtil; import com.utils.CommonUtil; /** * 岗位 * 后端接口 * author * email * date 2021-05-07 10:42:31 */ RestController RequestMapping(/gangwei) public class GangweiController { Autowired private GangweiService gangweiService; /** * 后端列表 */ RequestMapping(/page) public R page(RequestParam MapString, Object params,GangweiEntity gangwei, HttpServletRequest request){ EntityWrapperGangweiEntity ew new EntityWrapperGangweiEntity(); PageUtils page gangweiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, gangwei), params), params)); return R.ok().put(data, page); } /** * 前端列表 */ RequestMapping(/list) public R list(RequestParam MapString, Object params,GangweiEntity gangwei, HttpServletRequest request){ EntityWrapperGangweiEntity ew new EntityWrapperGangweiEntity(); PageUtils page gangweiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, gangwei), params), params)); return R.ok().put(data, page); } /** * 列表 */ RequestMapping(/lists) public R list( GangweiEntity gangwei){ EntityWrapperGangweiEntity ew new EntityWrapperGangweiEntity(); ew.allEq(MPUtil.allEQMapPre( gangwei, gangwei)); return R.ok().put(data, gangweiService.selectListView(ew)); } /** * 查询 */ RequestMapping(/query) public R query(GangweiEntity gangwei){ EntityWrapper GangweiEntity ew new EntityWrapper GangweiEntity(); ew.allEq(MPUtil.allEQMapPre( gangwei, gangwei)); GangweiView gangweiView gangweiService.selectView(ew); return R.ok(查询岗位成功).put(data, gangweiView); } /** * 后端详情 */ RequestMapping(/info/{id}) public R info(PathVariable(id) Long id){ GangweiEntity gangwei gangweiService.selectById(id); return R.ok().put(data, gangwei); } /** * 前端详情 */ RequestMapping(/detail/{id}) public R detail(PathVariable(id) Long id){ GangweiEntity gangwei gangweiService.selectById(id); return R.ok().put(data, gangwei); } /** * 后端保存 */ RequestMapping(/save) public R save(RequestBody GangweiEntity gangwei, HttpServletRequest request){ gangwei.setId(new Date().getTime()new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(gangwei); gangweiService.insert(gangwei); return R.ok(); } /** * 前端保存 */ RequestMapping(/add) public R add(RequestBody GangweiEntity gangwei, HttpServletRequest request){ gangwei.setId(new Date().getTime()new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(gangwei); gangweiService.insert(gangwei); return R.ok(); } /** * 修改 */ RequestMapping(/update) public R update(RequestBody GangweiEntity gangwei, HttpServletRequest request){ //ValidatorUtils.validateEntity(gangwei); gangweiService.updateById(gangwei);//全部更新 return R.ok(); } /** * 删除 */ RequestMapping(/delete) public R delete(RequestBody Long[] ids){ gangweiService.deleteBatchIds(Arrays.asList(ids)); return R.ok(); } /** * 提醒接口 */ RequestMapping(/remind/{columnName}/{type}) public R remindCount(PathVariable(columnName) String columnName, HttpServletRequest request, PathVariable(type) String type,RequestParam MapString, Object map) { map.put(column, columnName); map.put(type, type); if(type.equals(2)) { SimpleDateFormat sdf new SimpleDateFormat(yyyy-MM-dd); Calendar c Calendar.getInstance(); Date remindStartDate null; Date remindEndDate null; if(map.get(remindstart)!null) { Integer remindStart Integer.parseInt(map.get(remindstart).toString()); c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindStart); remindStartDate c.getTime(); map.put(remindstart, sdf.format(remindStartDate)); } if(map.get(remindend)!null) { Integer remindEnd Integer.parseInt(map.get(remindend).toString()); c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindEnd); remindEndDate c.getTime(); map.put(remindend, sdf.format(remindEndDate)); } } WrapperGangweiEntity wrapper new EntityWrapperGangweiEntity(); if(map.get(remindstart)!null) { wrapper.ge(columnName, map.get(remindstart)); } if(map.get(remindend)!null) { wrapper.le(columnName, map.get(remindend)); } int count gangweiService.selectCount(wrapper); return R.ok().put(count, count); } } package com.controller; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Arrays; import java.util.Calendar; import java.util.Map; import java.util.HashMap; import java.util.Iterator; import java.util.Date; import java.util.List; import javax.servlet.http.HttpServletRequest; import com.utils.ValidatorUtils; import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.format.annotation.DateTimeFormat; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.baomidou.mybatisplus.mapper.Wrapper; import com.annotation.IgnoreAuth; import com.entity.JixiaokaoheEntity; import com.entity.view.JixiaokaoheView; import com.service.JixiaokaoheService; import com.service.TokenService; import com.utils.PageUtils; import com.utils.R; import com.utils.MD5Util; import com.utils.MPUtil; import com.utils.CommonUtil; /** * 绩效考核 * 后端接口 * author * email * date 2021-05-07 10:42:31 */ RestController RequestMapping(/jixiaokaohe) public class JixiaokaoheController { Autowired private JixiaokaoheService jixiaokaoheService; /** * 后端列表 */ RequestMapping(/page) public R page(RequestParam MapString, Object params,JixiaokaoheEntity jixiaokaohe, HttpServletRequest request){ String tableName request.getSession().getAttribute(tableName).toString(); if(tableName.equals(yuangong)) { jixiaokaohe.setYuangonggonghao((String)request.getSession().getAttribute(username)); } EntityWrapperJixiaokaoheEntity ew new EntityWrapperJixiaokaoheEntity(); PageUtils page jixiaokaoheService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jixiaokaohe), params), params)); return R.ok().put(data, page); } /** * 前端列表 */ RequestMapping(/list) public R list(RequestParam MapString, Object params,JixiaokaoheEntity jixiaokaohe, HttpServletRequest request){ EntityWrapperJixiaokaoheEntity ew new EntityWrapperJixiaokaoheEntity(); PageUtils page jixiaokaoheService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jixiaokaohe), params), params)); return R.ok().put(data, page); } /** * 列表 */ RequestMapping(/lists) public R list( JixiaokaoheEntity jixiaokaohe){ EntityWrapperJixiaokaoheEntity ew new EntityWrapperJixiaokaoheEntity(); ew.allEq(MPUtil.allEQMapPre( jixiaokaohe, jixiaokaohe)); return R.ok().put(data, jixiaokaoheService.selectListView(ew)); } /** * 查询 */ RequestMapping(/query) public R query(JixiaokaoheEntity jixiaokaohe){ EntityWrapper JixiaokaoheEntity ew new EntityWrapper JixiaokaoheEntity(); ew.allEq(MPUtil.allEQMapPre( jixiaokaohe, jixiaokaohe)); JixiaokaoheView jixiaokaoheView jixiaokaoheService.selectView(ew); return R.ok(查询绩效考核成功).put(data, jixiaokaoheView); } /** * 后端详情 */ RequestMapping(/info/{id}) public R info(PathVariable(id) Long id){ JixiaokaoheEntity jixiaokaohe jixiaokaoheService.selectById(id); return R.ok().put(data, jixiaokaohe); } /** * 前端详情 */ RequestMapping(/detail/{id}) public R detail(PathVariable(id) Long id){ JixiaokaoheEntity jixiaokaohe jixiaokaoheService.selectById(id); return R.ok().put(data, jixiaokaohe); } /** * 后端保存 */ RequestMapping(/save) public R save(RequestBody JixiaokaoheEntity jixiaokaohe, HttpServletRequest request){ jixiaokaohe.setId(new Date().getTime()new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(jixiaokaohe); jixiaokaoheService.insert(jixiaokaohe); return R.ok(); } /** * 前端保存 */ RequestMapping(/add) public R add(RequestBody JixiaokaoheEntity jixiaokaohe, HttpServletRequest request){ jixiaokaohe.setId(new Date().getTime()new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(jixiaokaohe); jixiaokaoheService.insert(jixiaokaohe); return R.ok(); } /** * 修改 */ RequestMapping(/update) public R update(RequestBody JixiaokaoheEntity jixiaokaohe, HttpServletRequest request){ //ValidatorUtils.validateEntity(jixiaokaohe); jixiaokaoheService.updateById(jixiaokaohe);//全部更新 return R.ok(); } /** * 删除 */ RequestMapping(/delete) public R delete(RequestBody Long[] ids){ jixiaokaoheService.deleteBatchIds(Arrays.asList(ids)); return R.ok(); } /** * 提醒接口 */ RequestMapping(/remind/{columnName}/{type}) public R remindCount(PathVariable(columnName) String columnName, HttpServletRequest request, PathVariable(type) String type,RequestParam MapString, Object map) { map.put(column, columnName); map.put(type, type); if(type.equals(2)) { SimpleDateFormat sdf new SimpleDateFormat(yyyy-MM-dd); Calendar c Calendar.getInstance(); Date remindStartDate null; Date remindEndDate null; if(map.get(remindstart)!null) { Integer remindStart Integer.parseInt(map.get(remindstart).toString()); c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindStart); remindStartDate c.getTime(); map.put(remindstart, sdf.format(remindStartDate)); } if(map.get(remindend)!null) { Integer remindEnd Integer.parseInt(map.get(remindend).toString()); c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindEnd); remindEndDate c.getTime(); map.put(remindend, sdf.format(remindEndDate)); } } WrapperJixiaokaoheEntity wrapper new EntityWrapperJixiaokaoheEntity(); if(map.get(remindstart)!null) { wrapper.ge(columnName, map.get(remindstart)); } if(map.get(remindend)!null) { wrapper.le(columnName, map.get(remindend)); } String tableName request.getSession().getAttribute(tableName).toString(); if(tableName.equals(yuangong)) { wrapper.eq(yuangonggonghao, (String)request.getSession().getAttribute(username)); } int count jixiaokaoheService.selectCount(wrapper); return R.ok().put(count, count); } }六、论文参考七、最新计算机毕设选题推荐最新计算机软件毕业设计选题大全-CSDN博客八、源码获取大家点赞、收藏、关注、评论啦 、获取联系方式在文章末尾