表notification_announcement (通知公告)
表performance_evaluation (绩效评估)
表performance_information (绩效信息)
表recruitment_information (招聘信息)
随着信息技术的快速发展,传统的人事管理方式已经无法满足现代医院高效、精准的管理需求。医院需要一种能够集成人员信息、考核、培训、薪酬等功能的人事管理系统,以提高管理效率和质量。为此,本文提出了一种基于Spring Boot的医院人事管理系统。Spring Boot作为一种轻量级、易上手的Java开发框架,具有快速构建Web应用程序的能力,非常适合用于开发基于Spring Boot的医院人事管理系统。
本文首先阐述了系统的研究背景和意义;然后对系统进行了可行性、功能性等分析;接着详细介绍了系统的设计原理和实现细节,包括系统架构设计、整体功能模块设计、数据库设计等;最后对系统进行了部署和测试。通过本系统的开发,医院可以更好地规划和管理人力资源,提高员工的工作积极性和满意度,进而提升医院的整体竞争力。
关键词:医院;人事管理;Spring Boot
Abstract
With the rapid development of information technology, traditional personnel management methods can no longer meet the efficient and accurate management needs of modern hospitals. Hospitals need a personnel management system that can integrate functions such as personnel information, assessment, training, and compensation to improve management efficiency and quality. Therefore, this article proposes a hospital personnel management system based on Spring Boot. Spring Boot, as a lightweight and easy-to-use Java development framework, has the ability to quickly build web applications and is very suitable for developing hospital personnel management systems based on Spring Boot.
This article first elaborates on the research background and significance of the system; Then, feasibility and functionality analyses were conducted on the system; Then, the design principles and implementation details of the system were introduced in detail, including system architecture design, overall functional module design, database design, etc; Finally, the system was deployed and tested. Through the development of this system, hospitals can better plan and manage human resources, improve employee motivation and satisfaction, and thereby enhance the overall competitiveness of the hospital.
Keywords: Hospitals; Personnel management; Spring Boot
1 绪论
1.1 研究背景
随着医疗行业的快速发展,医院的人事管理工作面临着越来越多的挑战。传统的人事管理方式往往存在效率低下、信息不准确、数据难以共享等问题,已经无法满足现代医院管理的需求。因此,开发一套高效、准确、易用的人事管理系统成为医院管理工作的迫切需求。
Spring Boot是一个开源的Java框架,具有快速开发、简单易用、高度可配置等优点,被广泛应用于企业级应用的开发中。基于Spring Boot的医院人事管理系统可以利用该框架的这些优点,实现快速开发、部署和运维,提高系统的可靠性和稳定性。
研究基于Spring Boot的医院人事管理系统具有重要的意义,主要体现在以下几个方面:
首先,可以提高管理效率。通过系统实现员工信息的集中管理和自动化处理,如工资计算、考勤管理等,可以大大减少人工操作,提高人事管理的效率。
其次,可以确保数据准确性。系统采用标准化的数据处理流程,能够减少人为错误,保证人事数据的准确性,为医院管理决策提供可靠的数据支持。
再次,可以优化资源配置。系统可以根据医院的实际需求进行灵活配置,优化人力资源和财务资源的分配,提高医院运营效率。
最后,有助于推动医院信息化建设。人事管理系统的建设是医院信息化建设的重要组成部分,有助于提升医院整体管理水平,增强医院的竞争力。
论文将分层次进行编排,除去论文摘要致谢文献参考部分,论文主要架构如下:
第一章:绪论。主要介绍了课题研究的背景,研究意义和论文结构与章节安排。
第二章:系统分析。主要从系统的用户、功能等方面进行需求分析。
第三章:系统总体设计。主要对系统框架、系统功能模块、数据库进行功能设计。
第四章:系统详细设计与实现。主要介绍了系统功能界面的实现。
第五章:系统测试。主要对系统的部分界面进行测试并对主要功能进行测试。
第六章:总结。主要对系统的设计工作进行总结
2系统分析
2.1 可行性分析
(1)技术可行性
Spring Boot是一款成熟、稳定的开源Java框架,它提供了丰富的功能和强大的性能,非常适合用于构建Web应用。同时,Spring Boot具有简单易学、快速开发的特点,使得开发者能够更快速地开发出稳定、可靠的基于Spring Boot的医院人事管理系统。另外,MySQL是一种常用的关系型数据库,其稳定性、易用性和性能都经过了大量的实践验证,完全可以满足基于Spring Boot的医院人事管理系统的需求。因此,从技术层面分析是可行的。
(2)经济可行性
Spring Boot的自动配置功能可以根据应用程序的依赖和环境来进行自动配置,减少了大量的手动配置工作,可以降低开发成本;另外,Spring Boot的代码质量和可维护性较高,可以降低后期维护成本。因此,从经济角度分析是可行的。
(3)社会可行性
随着医疗信息化建设的不断深入,医院对于信息化系统的需求也在不断增加。开发基于Spring Boot的医院人事管理系统不仅可以满足医院的实际需求,还有助于推动医疗行业的信息化建设和发展。同时,系统的实施也符合国家对于医疗行业信息化建设的政策和规划。因此,从社会层面分析是可行的。
系统流程是用一些特定的符合和线条来进行演示用户在使用系统时的过程,在进行系统分析的时候,业务流程可以帮助开发人员更好的理解业务,发现错误,完善系统。
用户通过登录才能访问系统及权限以内的功能,对此将实现各种应用及管理等功能,用户登录流程图如下图2-1所示。
图2-1 登录流程图
2.2.2数据删除流程
如果系统里面存在一些没有用的数据,相关的管理人员还可以对这些数据进行删除,数据删除时流程图如下图2-3所示。
图2-2 数据删除流程图
按照基于Spring Boot的医院人事管理系统的角色,主要包括人事用户、员工用户和管理员这三大功能模块。
- 人事用户功能
- 登录:人事账号由管理员添加,用户可以用管理员提供的账号密码登录系统。
- 后台首页:用户可以查看后台展示的录用通知统计、员工考勤统计等统计图信息。
- 招聘信息管理:用户可以查看招聘信息列表中某个招聘信息的详情,可以对招聘信息进行增删改查操作。
- 录用通知管理:用户可以查看录用通知管理列表中某个招聘职位的详情并提交录用通知信息。可以查询、重置和删除录用通知信息。
- 员工档案管理:可以查看员工档案列表中某个员工档案的详情和提交工资信息,可以对员工档案信息进行增删改查操作。
- 员工工资管理:用户可以查看员工工资列表中某个员工工资的详情,可以查询、重置和删除员工工资信息。
- 员工考勤管理:员工用户可以查看员工考勤列表中某个员工的考勤详情并进行审核和回复,可以查询和重置员工考勤信息。
- 培训信息管理:员工用户可以查看培训信息列表中某个培训的详情。可以查对培训信息进行增删改查操作。
- 培训报名管理:员工用户可以查看培训报名列表中某个员工的报名详情并进行审核和回复,可以查询和重置培训报名信息。
- 培训情况管理:员工用户可以查看培训情况列表中某个员工的培训情况详情,可以查询和重置培训报名信息。
- 绩效信息管理:员工用户可以查看绩效信息列表中某个员工的绩效详情并提交绩效评估信息。可以查询和重置绩效信息。
- 绩效评估管理:员工用户可以查看绩效评估列表中某个员工的绩效评估详情,可以查询和重置绩效评估信息。
- 员工请假管理:员工用户可以查看员工请假列表中某个员工的请假详情并进行审核和回复,可以查询和重置员工请假信息。
- 离职信息管理:员工用户可以查看离职信息列表中某个员工的离职详情并进行审核和回复,可以查询和重置离职信息。
- 通知公告管理:用户可以查看管理员发布的通知公告信息,可以查询和重置通知公告信息。
- 我的:用户可以修改个人信息和登录密码,密码修改后可以用新密码登录系统;点击“退出”即可退出系统的登录。
- 员工用户功能
- 登录:员工账号由管理员添加,用户可以用管理员提供的账号密码登录系统。
- 后台首页:用户可以查看后台首页展示的相关信息。
- 员工档案管理:用户可以查看档案详情和下载合同文件、点击“离职”可以提交离职信息。
- 员工工资管理:用户可以查看工资列表中某个月份的工资详情,可以对列表信息进行查询和重置操作。
- 员工考勤管理:用户可以查看考勤列表中某个月份的考勤详情,可以对考勤信息进行增删改查操作。
- 培训信息管理:用户可以查看培训信息列表中某个培训的详情并可以提交培训报名信息,可以对列表信息进行查询和重置操作。
- 培训报名管理:用户可以查看培训报名列表中某个培训的报名详情,可以对列表信息进行查询、重置和删除操作。
- 培训情况管理:用户可以查看培训情况列表中某个培训情况信息详情,可以对培训情况信息进行查询和重置操作。
- 绩效信息管理:用户可以查看绩效信息列表中某个月的绩效信息详情,可以对绩效信息进行增删改查操作。
- 绩效评估管理:用户可以查看绩效评估列表中某个绩效评估信息详情,可以对绩效评估信息进行查询和重置操作。
- 员工请假管理:用户可以查看请假列表中某个请假信息详情,可以对请假信息进行增删改查操作。
- 福利申请管理:用户可以查看福利申请列表中某个福利申请的详情,可以对福利申请信息进行增删改查操作。
- 离职信息管理:用户可以查看离职信息列表中某个离职信息详情,可以对列表信息进行查询、重置和删除操作。
- 通知公告管理:用户可以查看通知公告列表中某个通知公告的详情,可以对列表信息进出查询和重置操作。
- 我的:用户可以修改个人信息和登录密码,密码修改后可以用新密码登录系统;点击“退出”即可退出系统的登录。
- 管理员功能
- 登录:管理员可以通过在后台输入正确的账号和密码进行登录。
- 后台首页:管理员可以查看后台首页展示的录用通知统计、员工考勤统计、员工请假统计等统计图信息。
- 系统用户:员工用户和人事用户账号均由管理员添加,管理员可以对用户信息进行查询、重置、添加和删除操作。
- 招聘信息管理:管理员可以查看招聘信息列表中某个招聘信息的详情,可以对招聘信息进行增删改查操作。
- 录用通知管理:管理员用户可以查看录用通知管理列表中某个招聘职位的录用详情,可以查询、重置和删除录用通知信息。
- 员工档案管理:管理员可以查看员工档案列表中某个员工档案的详情、工资和离职信息,可以对员工档案信息进行增删改查操作。
- 员工工资管理:管理员可以查看员工工资列表中某个员工工资的详情,可以对员工档案信息进行查询、重置和删除操作。
- 员工考勤管理:管理员可以查看员工考勤列表中某个员工考勤的详情,可以对员工考勤信息进行增删改查操作。
- 培训信息管理:管理员可以查看培训信息列表中某个培训的详情和培训报名信息,可以对培训信息进行增删改查操作。
- 培训报名管理:管理员可以查看培训报名列表中某个员工的培训报名详情并提交培训情况信息,可以对培训报名信息进行查询、重置和删除操作。
- 培训情况管理:管理员可以查看培训情况列表中某个员工的培训情况详情,可以对培训情况信息进行查询、重置和删除操作。
- 绩效信息管理:管理员可以查看绩效信息列表中某个员工的绩效信息详情和绩效评估,可以对绩效信息进行增删改查操作。
- 绩效评估管理:管理员可以查看绩效评估列表中某个员工的培绩效评估详情,可以对绩效评估信息进行查询、重置和删除操作。
- 员工请假管理:管理员可以查看员工请假列表中某个员工的请假详情,可以对员工请假信息进行查询、重置和删除操作。
- 福利申请管理:管理员可以查看福利申请列表中某个员工的福利申请详情并进行审核和回复;可以对福利申请信息进行增删改查操作。
- 离职信息管理:管理员可以查看离职信息列表中某个员工的离职详情,可以对离职信息进行查询、重置和删除操作。
- 通知公告管理:管理员可以查看通知公告列表中某一通知公告的详情;可以对通知公告信息进行增删改查操作。
- 权限管理:管理员可以查看权限列表中某个用户的权限详情,可以对用户权限进行增删改查操作。
- 我的:管理员可以修改个人信息和登录密码,密码修改后可以用新密码登录系统;点击“退出”即可退出系统的登录。
2.4 系统用例分析
通过2.3功能的分析,得出了本系统的用例图:
人事用户用例图如下图2-3所示。
图2-3 人事用户用例图
员工用户用例图如下图2-4所示。
图2-4 员工用户用例图
管理员用例图如下图2-5所示。
图2-5 管理员用例图
本章主要通过对基于Spring Boot的医院人事管理系统的可行性分析、流程分析、功能需求分析、系统用例分析,确定整个系统要实现的功能。同时也为系统的代码实现和测试提供了标准。
本章主要讨论的内容包括基于Spring Boot的医院人事管理系统的架构设计、功能模块设计、数据库系统设计。
3.1 系统架构设计
本系统从架构上分为三层:表现层(UI)、业务逻辑层(BLL)以及数据层(DL)。
图3-1系统架构设计图
表现层(UI):又称UI层,主要完成本系统的UI交互功能,一个良好的UI可以打打提高用户的用户体验,增强用户使用本系统时的舒适度。UI的界面设计也要适应不同版本的系统以及不同尺寸的分辨率,以做到良好的兼容性。UI交互功能要求合理,用户进行交互操作时必须要得到与之相符的交互结果,这就要求表现层要与业务逻辑层进行良好的对接。
业务逻辑层(BLL):主要完成本系统的数据处理功能。用户从表现层传输过来的数据经过业务逻辑层进行处理交付给数据层,系统从数据层读取的数据经过业务逻辑层进行处理交付给表现层。
数据层(DL):由于本系统的数据是放在服务端的MySQL数据库中,因此本属于服务层的部分可以直接整合在业务逻辑层中,所以数据层中只有数据库,其主要完成本系统的数据存储和管理功能。
3.2 系统功能模块设计
在上一章节中主要对系统的功能性需求和非功能性需求进行分析,并且根据需求分析了系统中的用例。那么接下来就要开始对本系统的主要功能和数据库开始进行设计。基于根据前面章节的需求分析得出,其总体设计模块图如图3-1所示。
图3-2 系统功能模块图
3.3 数据库设计
数据库设计一般包括需求分析、概念模型设计、数据库表建立三大过程,其中需求分析前面章节已经阐述,概念模型设计有概念模型和逻辑结构设计两部分。
3.3.1 数据库概念结构设计
下面是整个基于Spring Boot的医院人事管理系统中主要的数据库表总E-R实体关系图。
图3-3 系统总E-R关系图
3.3.2 数据库逻辑结构设计
通过上一小节中基于Spring Boot的医院人事管理系统中总E-R关系图上得出一共需要创建很多个数据表。在此主要罗列几个主要的数据库表结构设计。
表access_token (登陆访问时长)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | token_id | int | 10 | 0 | N | Y | 临时访问牌ID | |
2 | token | varchar | 64 | 0 | Y | N | 临时访问牌 | |
3 | info | text | 65535 | 0 | Y | N | ||
4 | maxage | int | 10 | 0 | N | N | 2 | 最大寿命:默认2小时 |
5 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
6 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
7 | user_id | int | 10 | 0 | N | N | 0 | 用户编号: |
表auth (用户权限管理)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | auth_id | int | 10 | 0 | N | Y | 授权ID: | |
2 | user_group | varchar | 64 | 0 | Y | N | 用户组: | |
3 | mod_name | varchar | 64 | 0 | Y | N | 模块名: | |
4 | table_name | varchar | 64 | 0 | Y | N | 表名: | |
5 | page_title | varchar | 255 | 0 | Y | N | 页面标题: | |
6 | path | varchar | 255 | 0 | Y | N | 路由路径: | |
7 | position | varchar | 32 | 0 | Y | N | 位置: | |
8 | mode | varchar | 32 | 0 | N | N | _blank | 跳转方式: |
9 | add | tinyint | 3 | 0 | N | N | 1 | 是否可增加: |
10 | del | tinyint | 3 | 0 | N | N | 1 | 是否可删除: |
11 | set | tinyint | 3 | 0 | N | N | 1 | 是否可修改: |
12 | get | tinyint | 3 | 0 | N | N | 1 | 是否可查看: |
13 | field_add | text | 65535 | 0 | Y | N | 添加字段: | |
14 | field_set | text | 65535 | 0 | Y | N | 修改字段: | |
15 | field_get | text | 65535 | 0 | Y | N | 查询字段: | |
16 | table_nav_name | varchar | 500 | 0 | Y | N | 跨表导航名称: | |
17 | table_nav | varchar | 500 | 0 | Y | N | 跨表导航: | |
18 | option | text | 65535 | 0 | Y | N | 配置: | |
19 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
20 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
表employee_attendance (员工考勤)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | employee_attendance_id | int | 10 | 0 | N | Y | 员工考勤ID | |
2 | employee_users | int | 10 | 0 | Y | N | 0 | 员工用户 |
3 | employee_no | varchar | 64 | 0 | Y | N | 员工工号 | |
4 | employee_name | varchar | 64 | 0 | Y | N | 员工姓名 | |
5 | attendance_month | varchar | 64 | 0 | Y | N | 考勤月份 | |
6 | attendance_date | date | 10 | 0 | Y | N | 考勤日期 | |
7 | check_in_time | datetime | 19 | 0 | Y | N | 打卡时间 | |
8 | attendance_status | varchar | 64 | 0 | Y | N | 考勤状态 | |
9 | attendance_instructions | text | 65535 | 0 | Y | N | 考勤说明 | |
10 | examine_state | varchar | 16 | 0 | N | N | 未审核 | 审核状态 |
11 | examine_reply | varchar | 16 | 0 | Y | N | 审核回复 | |
12 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
13 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
表employee_files (员工档案)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | employee_files_id | int | 10 | 0 | N | Y | 员工档案ID | |
2 | personnel_users | int | 10 | 0 | Y | N | 0 | 人事用户 |
3 | employee_users | int | 10 | 0 | Y | N | 0 | 员工用户 |
4 | employee_no | varchar | 64 | 0 | Y | N | 员工工号 | |
5 | employee_name | varchar | 64 | 0 | Y | N | 员工姓名 | |
6 | employee_age | varchar | 64 | 0 | Y | N | 员工年龄 | |
7 | employee_gender | varchar | 64 | 0 | Y | N | 员工性别 | |
8 | employee_phone_number | varchar | 64 | 0 | Y | N | 员工电话 | |
9 | id_number | varchar | 255 | 0 | Y | N | 身份证号 | |
10 | home_address | varchar | 64 | 0 | Y | N | 家庭住址 | |
11 | the_highest_educational_level | varchar | 64 | 0 | Y | N | 最高学历 | |
12 | date_of_employment | date | 10 | 0 | Y | N | 入职时间 | |
13 | department_name | varchar | 64 | 0 | Y | N | 部门名称 | |
14 | employee_positions | varchar | 64 | 0 | Y | N | 员工职位 | |
15 | personal_information | text | 65535 | 0 | Y | N | 个人信息 | |
16 | contract_information | text | 65535 | 0 | Y | N | 合同信息 | |
17 | training_records | text | 65535 | 0 | Y | N | 培训记录 | |
18 | contract_documents | varchar | 255 | 0 | Y | N | 合同文件 | |
19 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
20 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
表employee_leave (员工请假)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | employee_leave_id | int | 10 | 0 | N | Y | 员工请假ID | |
2 | employee_users | int | 10 | 0 | Y | N | 0 | 员工用户 |
3 | employee_no | varchar | 64 | 0 | Y | N | 员工工号 | |
4 | employee_name | varchar | 64 | 0 | Y | N | 员工姓名 | |
5 | leave_type | varchar | 64 | 0 | Y | N | 休假类型 | |
6 | start_time | datetime | 19 | 0 | Y | N | 开始时间 | |
7 | end_time | datetime | 19 | 0 | Y | N | 结束时间 | |
8 | reason_for_leave | text | 65535 | 0 | Y | N | 请假原因 | |
9 | examine_state | varchar | 16 | 0 | N | N | 未审核 | 审核状态 |
10 | examine_reply | varchar | 16 | 0 | Y | N | 审核回复 | |
11 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
12 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
表employee_salaries (员工工资)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | employee_salaries_id | int | 10 | 0 | N | Y | 员工工资ID | |
2 | personnel_users | int | 10 | 0 | Y | N | 0 | 人事用户 |
3 | employee_users | int | 10 | 0 | Y | N | 0 | 员工用户 |
4 | employee_no | varchar | 64 | 0 | Y | N | 员工工号 | |
5 | employee_name | varchar | 64 | 0 | Y | N | 员工姓名 | |
6 | salary_month | varchar | 64 | 0 | Y | N | 发薪月份 | |
7 | distribution_time | date | 10 | 0 | Y | N | 发放时间 | |
8 | basic_salary | varchar | 64 | 0 | Y | N | 基本工资 | |
9 | overtime_wages | varchar | 64 | 0 | Y | N | 加班工资 | |
10 | bonus_amount | varchar | 64 | 0 | Y | N | 奖金金额 | |
11 | allowance_amount | varchar | 64 | 0 | Y | N | 津贴金额 | |
12 | penalty_amount | varchar | 64 | 0 | Y | N | 罚款金额 | |
13 | attendance_deduction | varchar | 64 | 0 | Y | N | 考勤扣款 | |
14 | net_salary | varchar | 64 | 0 | Y | N | 实发工资 | |
15 | salary_details | text | 65535 | 0 | Y | N | 工资明细 | |
16 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
17 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
表employee_users (员工用户)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | employee_users_id | int | 10 | 0 | N | Y | 员工用户ID | |
2 | employee_no | varchar | 64 | 0 | N | N | 员工工号 | |
3 | employee_name | varchar | 64 | 0 | Y | N | 员工姓名 | |
4 | employee_positions | varchar | 64 | 0 | Y | N | 员工职位 | |
5 | department_name | varchar | 64 | 0 | Y | N | 部门名称 | |
6 | employee_phone_number | varchar | 64 | 0 | Y | N | 员工电话 | |
7 | working_hours | varchar | 64 | 0 | Y | N | 工作时间 | |
8 | examine_state | varchar | 16 | 0 | N | N | 已通过 | 审核状态 |
9 | user_id | int | 10 | 0 | N | N | 0 | 用户ID |
10 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
11 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
表employment_notice (录用通知)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | employment_notice_id | int | 10 | 0 | N | Y | 录用通知ID | |
2 | responsible_for_personnel | int | 10 | 0 | Y | N | 0 | 负责人事 |
3 | department_name | varchar | 64 | 0 | Y | N | 部门名称 | |
4 | recruitment_positions | varchar | 64 | 0 | Y | N | 招聘职位 | |
5 | position_type | varchar | 64 | 0 | Y | N | 职位类型 | |
6 | number_of_recruiters | varchar | 64 | 0 | Y | N | 招聘人数 | |
7 | recruitment_time | datetime | 19 | 0 | Y | N | 招聘时间 | |
8 | recruitment_location | varchar | 64 | 0 | Y | N | 招聘地点 | |
9 | number_of_applicants | varchar | 64 | 0 | Y | N | 应聘人数 | |
10 | number_of_employed_personnel | varchar | 64 | 0 | Y | N | 录用人数 | |
11 | recruitment_effectiveness | varchar | 64 | 0 | Y | N | 招聘效果 | |
12 | employment_date | date | 10 | 0 | Y | N | 录用日期 | |
13 | hiring_personnel | text | 65535 | 0 | Y | N | 录用人员 | |
14 | notification_content | text | 65535 | 0 | Y | N | 通知内容 | |
15 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
16 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
表hits (用户点击)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | hits_id | int | 10 | 0 | N | Y | 点赞ID: | |
2 | user_id | int | 10 | 0 | N | N | 0 | 点赞人: |
3 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
4 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
5 | source_table | varchar | 255 | 0 | Y | N | 来源表: | |
6 | source_field | varchar | 255 | 0 | Y | N | 来源字段: | |
7 | source_id | int | 10 | 0 | N | N | 0 | 来源ID: |
表notification_announcement (通知公告)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | notification_announcement_id | int | 10 | 0 | N | Y | 通知公告ID | |
2 | announcement_title | varchar | 64 | 0 | Y | N | 公告标题 | |
3 | release_time | date | 10 | 0 | Y | N | 发布时间 | |
4 | publisher | varchar | 64 | 0 | Y | N | 发布人 | |
5 | announcement_content | text | 65535 | 0 | Y | N | 公告内容 | |
6 | related_documents | varchar | 255 | 0 | Y | N | 相关文件 | |
7 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
8 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
表performance_evaluation (绩效评估)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | performance_evaluation_id | int | 10 | 0 | N | Y | 绩效评估ID | |
2 | employee_users | int | 10 | 0 | Y | N | 0 | 员工用户 |
3 | employee_no | varchar | 64 | 0 | Y | N | 员工工号 | |
4 | employee_name | varchar | 64 | 0 | Y | N | 员工姓名 | |
5 | performance_goals | varchar | 64 | 0 | Y | N | 绩效目标 | |
6 | target_type | varchar | 64 | 0 | Y | N | 目标类型 | |
7 | target_time | varchar | 64 | 0 | Y | N | 目标时间 | |
8 | completion_status | text | 65535 | 0 | Y | N | 完成情况 | |
9 | personnel_users | int | 10 | 0 | Y | N | 0 | 人事用户 |
10 | evaluation_date | date | 10 | 0 | Y | N | 评估日期 | |
11 | evaluation_score | varchar | 64 | 0 | Y | N | 评估分数 | |
12 | evaluation_content | text | 65535 | 0 | Y | N | 评估内容 | |
13 | feedback_content | text | 65535 | 0 | Y | N | 反馈内容 | |
14 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
15 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
表performance_information (绩效信息)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | performance_information_id | int | 10 | 0 | N | Y | 绩效信息ID | |
2 | employee_users | int | 10 | 0 | Y | N | 0 | 员工用户 |
3 | employee_no | varchar | 64 | 0 | Y | N | 员工工号 | |
4 | employee_name | varchar | 64 | 0 | Y | N | 员工姓名 | |
5 | performance_goals | varchar | 64 | 0 | Y | N | 绩效目标 | |
6 | target_type | varchar | 64 | 0 | Y | N | 目标类型 | |
7 | target_time | varchar | 64 | 0 | Y | N | 目标时间 | |
8 | target_content | text | 65535 | 0 | Y | N | 目标内容 | |
9 | target_progress | text | 65535 | 0 | Y | N | 目标进度 | |
10 | completion_status | text | 65535 | 0 | Y | N | 完成情况 | |
11 | self_evaluation | text | 65535 | 0 | Y | N | 自我评估 | |
12 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
13 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
表personnel_users (人事用户)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | personnel_users_id | int | 10 | 0 | N | Y | 人事用户ID | |
2 | personnel_no | varchar | 64 | 0 | N | N | 人事工号 | |
3 | personnel_name | varchar | 64 | 0 | Y | N | 人事姓名 | |
4 | examine_state | varchar | 16 | 0 | N | N | 已通过 | 审核状态 |
5 | user_id | int | 10 | 0 | N | N | 0 | 用户ID |
6 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
7 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
表recruitment_information (招聘信息)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | recruitment_information_id | int | 10 | 0 | N | Y | 招聘信息ID | |
2 | responsible_for_personnel | int | 10 | 0 | Y | N | 0 | 负责人事 |
3 | department_name | varchar | 64 | 0 | Y | N | 部门名称 | |
4 | recruitment_positions | varchar | 64 | 0 | Y | N | 招聘职位 | |
5 | position_type | varchar | 64 | 0 | Y | N | 职位类型 | |
6 | number_of_recruiters | varchar | 64 | 0 | Y | N | 招聘人数 | |
7 | recruitment_time | datetime | 19 | 0 | Y | N | 招聘时间 | |
8 | recruitment_location | varchar | 64 | 0 | Y | N | 招聘地点 | |
9 | position_salary | varchar | 64 | 0 | Y | N | 职位薪资 | |
10 | educational_requirements | varchar | 64 | 0 | Y | N | 学历要求 | |
11 | job_requirements | text | 65535 | 0 | Y | N | 岗位需求 | |
12 | job_description | text | 65535 | 0 | Y | N | 职位内容 | |
13 | welfare_treatment | text | 65535 | 0 | Y | N | 福利待遇 | |
14 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
15 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
表resignation_information (离职信息)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | resignation_information_id | int | 10 | 0 | N | Y | 离职信息ID | |
2 | personnel_users | int | 10 | 0 | Y | N | 0 | 人事用户 |
3 | employee_users | int | 10 | 0 | Y | N | 0 | 员工用户 |
4 | employee_no | varchar | 64 | 0 | Y | N | 员工工号 | |
5 | employee_name | varchar | 64 | 0 | Y | N | 员工姓名 | |
6 | employee_gender | varchar | 64 | 0 | Y | N | 员工性别 | |
7 | employee_phone_number | varchar | 64 | 0 | Y | N | 员工电话 | |
8 | date_of_employment | date | 10 | 0 | Y | N | 入职时间 | |
9 | department_name | varchar | 64 | 0 | Y | N | 部门名称 | |
10 | employee_positions | varchar | 64 | 0 | Y | N | 员工职位 | |
11 | resignation_date | date | 10 | 0 | Y | N | 离职日期 | |
12 | number_of_resignations | varchar | 64 | 0 | Y | N | 离职人数 | |
13 | reason_for_resignation | text | 65535 | 0 | Y | N | 离职原因 | |
14 | examine_state | varchar | 16 | 0 | N | N | 未审核 | 审核状态 |
15 | examine_reply | varchar | 16 | 0 | Y | N | 审核回复 | |
16 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
17 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
表training_information (培训信息)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | training_information_id | int | 10 | 0 | N | Y | 培训信息ID | |
2 | personnel_users | int | 10 | 0 | Y | N | 0 | 人事用户 |
3 | training_name | varchar | 64 | 0 | Y | N | 培训名称 | |
4 | training_type | varchar | 64 | 0 | Y | N | 培训类型 | |
5 | training_time | varchar | 64 | 0 | Y | N | 培训时间 | |
6 | training_location | varchar | 64 | 0 | Y | N | 培训地点 | |
7 | training_targets | varchar | 64 | 0 | Y | N | 培训对象 | |
8 | training_duration | varchar | 64 | 0 | Y | N | 培训时长 | |
9 | training_content | text | 65535 | 0 | Y | N | 培训内容 | |
10 | training_points | text | 65535 | 0 | Y | N | 培训要点 | |
11 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
12 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
表training_registration (培训报名)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | training_registration_id | int | 10 | 0 | N | Y | 培训报名ID | |
2 | personnel_users | int | 10 | 0 | Y | N | 0 | 人事用户 |
3 | training_name | varchar | 64 | 0 | Y | N | 培训名称 | |
4 | training_type | varchar | 64 | 0 | Y | N | 培训类型 | |
5 | training_time | varchar | 64 | 0 | Y | N | 培训时间 | |
6 | training_location | varchar | 64 | 0 | Y | N | 培训地点 | |
7 | training_targets | varchar | 64 | 0 | Y | N | 培训对象 | |
8 | training_duration | varchar | 64 | 0 | Y | N | 培训时长 | |
9 | employee_users | int | 10 | 0 | Y | N | 0 | 员工用户 |
10 | employee_no | varchar | 64 | 0 | Y | N | 员工工号 | |
11 | employee_name | varchar | 64 | 0 | Y | N | 员工姓名 | |
12 | registration_date | date | 10 | 0 | Y | N | 报名日期 | |
13 | reason_for_registration | text | 65535 | 0 | Y | N | 报名原因 | |
14 | examine_state | varchar | 16 | 0 | N | N | 未审核 | 审核状态 |
15 | examine_reply | varchar | 16 | 0 | Y | N | 审核回复 | |
16 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
17 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
表training_situation (培训情况)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | training_situation_id | int | 10 | 0 | N | Y | 培训情况ID | |
2 | personnel_users | int | 10 | 0 | Y | N | 0 | 人事用户 |
3 | training_name | varchar | 64 | 0 | Y | N | 培训名称 | |
4 | training_type | varchar | 64 | 0 | Y | N | 培训类型 | |
5 | training_time | varchar | 64 | 0 | Y | N | 培训时间 | |
6 | training_location | varchar | 64 | 0 | Y | N | 培训地点 | |
7 | training_targets | varchar | 64 | 0 | Y | N | 培训对象 | |
8 | training_duration | varchar | 64 | 0 | Y | N | 培训时长 | |
9 | employee_users | int | 10 | 0 | Y | N | 0 | 员工用户 |
10 | employee_no | varchar | 64 | 0 | Y | N | 员工工号 | |
11 | employee_name | varchar | 64 | 0 | Y | N | 员工姓名 | |
12 | training_situation | text | 65535 | 0 | Y | N | 培训情况 | |
13 | participation_situation | text | 65535 | 0 | Y | N | 参与情况 | |
14 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
15 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
表upload (文件上传)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | upload_id | int | 10 | 0 | N | Y | 上传ID | |
2 | name | varchar | 64 | 0 | Y | N | 文件名 | |
3 | path | varchar | 255 | 0 | Y | N | 访问路径 | |
4 | file | varchar | 255 | 0 | Y | N | 文件路径 | |
5 | display | varchar | 255 | 0 | Y | N | 显示顺序 | |
6 | father_id | int | 10 | 0 | Y | N | 0 | 父级ID |
7 | dir | varchar | 255 | 0 | Y | N | 文件夹 | |
8 | type | varchar | 32 | 0 | Y | N | 文件类型 |
表user (用户账户:用于保存用户登录信息)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | user_id | mediumint | 8 | 0 | N | Y | 用户ID:[0,8388607]用户获取其他与用户相关的数据 | |
2 | state | smallint | 5 | 0 | N | N | 1 | 账户状态:[0,10](1可用|2异常|3已冻结|4已注销) |
3 | user_group | varchar | 32 | 0 | Y | N | 所在用户组:[0,32767]决定用户身份和权限 | |
4 | login_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 上次登录时间: |
5 | phone | varchar | 11 | 0 | Y | N | 手机号码:[0,11]用户的手机号码,用于找回密码时或登录时 | |
6 | phone_state | smallint | 5 | 0 | N | N | 0 | 手机认证:[0,1](0未认证|1审核中|2已认证) |
7 | username | varchar | 16 | 0 | N | N | 用户名:[0,16]用户登录时所用的账户名称 | |
8 | nickname | varchar | 16 | 0 | Y | N | 昵称:[0,16] | |
9 | password | varchar | 64 | 0 | N | N | 密码:[0,32]用户登录所需的密码,由6-16位数字或英文组成 | |
10 | | varchar | 64 | 0 | Y | N | 邮箱:[0,64]用户的邮箱,用于找回密码时或登录时 | |
11 | email_state | smallint | 5 | 0 | N | N | 0 | 邮箱认证:[0,1](0未认证|1审核中|2已认证) |
12 | avatar | varchar | 255 | 0 | Y | N | 头像地址:[0,255] | |
13 | open_id | varchar | 255 | 0 | Y | N | 针对获取用户信息字段 | |
14 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
15 | vip_level | varchar | 255 | 0 | Y | N | 会员等级 | |
16 | vip_discount | double | 11 | 2 | Y | N | 0.00 | 会员折扣 |
表user_group (用户组:用于用户前端身份和鉴权)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | group_id | mediumint | 8 | 0 | N | Y | 用户组ID:[0,8388607] | |
2 | display | smallint | 5 | 0 | N | N | 100 | 显示顺序:[0,1000] |
3 | name | varchar | 16 | 0 | N | N | 名称:[0,16] | |
4 | description | varchar | 255 | 0 | Y | N | 描述:[0,255]描述该用户组的特点或权限范围 | |
5 | source_table | varchar | 255 | 0 | Y | N | 来源表: | |
6 | source_field | varchar | 255 | 0 | Y | N | 来源字段: | |
7 | source_id | int | 10 | 0 | N | N | 0 | 来源ID: |
8 | register | smallint | 5 | 0 | Y | N | 0 | 注册位置: |
9 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
10 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
表welfare_application (福利申请)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | welfare_application_id | int | 10 | 0 | N | Y | 福利申请ID | |
2 | employee_users | int | 10 | 0 | Y | N | 0 | 员工用户 |
3 | employee_no | varchar | 64 | 0 | Y | N | 员工工号 | |
4 | employee_name | varchar | 64 | 0 | Y | N | 员工姓名 | |
5 | application_project | varchar | 64 | 0 | Y | N | 申请项目 | |
6 | application_type | varchar | 64 | 0 | Y | N | 申请类型 | |
7 | application_date | date | 10 | 0 | Y | N | 申请日期 | |
8 | application_content | text | 65535 | 0 | Y | N | 申请内容 | |
9 | application_materials | varchar | 255 | 0 | Y | N | 申请材料 | |
10 | examine_state | varchar | 16 | 0 | N | N | 未审核 | 审核状态 |
11 | examine_reply | varchar | 16 | 0 | Y | N | 审核回复 | |
12 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
13 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
3.4本章小结
整个基于Spring Boot的医院人事管理系统的需求分析主要对系统总体架构以及功能模块的设计,通过建立E-R模型和数据库逻辑系统设计完成了数据库系统设计。
4 系统详细设计与实现
4.1人事用户功能模块
员工用户可以查看录用通知列表中某个招聘职位的详情并提交录用通知信息。可以查询、重置和删除录用通知信息。其界面如下图4-1所示:
图4-1录用通知管理界面图
用户可以添加员工档案信息,可以查看员工档案列表中某个员工档案的详情和提交工资信息,点击列表中的“点击下载”可以下载需要上传的合同文件信息。可以查询、重置和删除列表信息。其界面如下图4-2所示:
文件上传的代码如下:
@PostMapping("/upload")
public Map<String, Object> upload(@RequestParam("file") MultipartFile file) {
log.info("进入方法");
if (file.isEmpty()) {
return error(30000, "没有选择文件");
}
try {
//判断有没路径,没有则创建
String filePath = System.getProperty("user.dir") + "/src/main/resources/static/";
File targetDir = new File(filePath);
if (!targetDir.exists() && !targetDir.isDirectory()) {
if (targetDir.mkdirs()) {
log.info("创建目录成功");
} else {
log.error("创建目录失败");
}
}
String fileName = file.getOriginalFilename();
File dest = new File(filePath + fileName);
log.info("文件路径:{}", dest.getPath());
log.info("文件名:{}", dest.getName());
file.transferTo(dest);
JSONObject jsonObject = new JSONObject();
jsonObject.put("url", "/api/upload/" + fileName);
return success(jsonObject);
} catch (IOException e) {
log.info("上传失败:{}", e.getMessage());
}
return error(30000, "上传失败");
}
员工用户可以查看员工考勤列表中某个员工的考勤详情。可以查询和重置员工考勤信息。其界面如下图4-3所示:
员工用户可以查看绩效信息列表中某个员工的绩效详情并提交绩效评估信息。可以查询和重置绩效信息。其界面如下图4-4所示:
员工用户可以查看员工请假列表中某个员工的请假的详情并进行审核和回复。可以查询和重置员工请假信息。其界面如下图4-5所示:
用户登录界面用于已注册用户进行账号登录,用户需要输入正确的用户名和密码才能成功登录系统。登录界面应对用户的输入进行验证,并提供密码找回的选项。其界面如下图4-6所示。
图4-6用户登录界面图
登录代码如下:
/**
* 登录
* @param data
* @param httpServletRequest
* @return
*/
@PostMapping("login")
public Map<String, Object> login(@RequestBody Map<String, String> data, HttpServletRequest httpServletRequest) {
log.info("[执行登录接口]");
String username = data.get("username");
String email = data.get("email");
String phone = data.get("phone");
String password = data.get("password");
List resultList = null;
Map<String, String> map = new HashMap<>();
if(username != null && "".equals(username) == false){
map.put("username", username);
resultList = service.selectBaseList(service.select(map, new HashMap<>()));
}
else if(email != null && "".equals(email) == false){
map.put("email", email);
resultList = service.selectBaseList(service.select(map, new HashMap<>()));
}
else if(phone != null && "".equals(phone) == false){
map.put("phone", phone);
resultList = service.selectBaseList(service.select(map, new HashMap<>()));
}else{
return error(30000, "账号或密码不能为空");
}
if (resultList == null || password == null) {
return error(30000, "账号或密码不能为空");
}
//判断是否有这个用户
if (resultList.size()<=0){
return error(30000,"用户不存在");
}
User byUsername = (User) resultList.get(0);
Map<String, String> groupMap = new HashMap<>();
groupMap.put("name",byUsername.getUserGroup());
List groupList = userGroupService.selectBaseList(userGroupService.select(groupMap, new HashMap<>()));
if (groupList.size()<1){
return error(30000,"用户组不存在");
}
UserGroup userGroup = (UserGroup) groupList.get(0);
//查询用户审核状态
if (!StringUtils.isEmpty(userGroup.getSourceTable())){
String res = service.selectExamineState(userGroup.getSourceTable(),byUsername.getUserId());
if (res==null){
return error(30000,"用户不存在");
}
if (!res.equals("已通过")){
return error(30000,"该用户审核未通过");
}
}
//查询用户状态
if (byUsername.getState()!=1){
return error(30000,"用户非可用状态,不能登录");
}
String md5password = service.encryption(password);
if (byUsername.getPassword().equals(md5password)) {
// 存储Token到数据库
AccessToken accessToken = new AccessToken();
accessToken.setToken(UUID.randomUUID().toString().replaceAll("-", ""));
accessToken.setUser_id(byUsername.getUserId());
Duration duration = Duration.ofSeconds(7200L);
redisTemplate.opsForValue().set(accessToken.getToken(), accessToken,duration);
// 返回用户信息
JSONObject user = JSONObject.parseObject(JSONObject.toJSONString(byUsername));
user.put("token", accessToken.getToken());
JSONObject ret = new JSONObject();
ret.put("obj",user);
return success(ret);
} else {
return error(30000, "账号或密码不正确");
}
}
用户可以查看工资列表中某个月份的工资详情,可以对列表信息进行查询和重置操作。其界面如下图4-7所示。
图4-7员工工资管理界面图
用户可以查看培训信息列表中某个培训的详情并可以提交培训报名信息,可以对列表信息进行查询和重置操作。其界面如下图4-8所示。
图4-8培训信息管理界面图
用户点击“福利申请添加”进入页面填写申请项目、申请类型、申请内容等信息后点击“提交”即可完成福利申请的添加,可以查看福利申请列表中某个福利申请的详情,可以对列表信息进行查询、重置和删除操作。其界面如下图4-9所示。
图4-9福利申请管理界面图
4.3管理员功能模块
管理员可以查看系统用户(管理员、员工用户、人事用户)列表中某个用户的详情,可以对用户信息进行查询、重置、添加和删除操作。员工用户和人事用户账号均由管理员添加。其界面如下图4-10所示。
图4-10系统用户界面图
添加的代码如下:
@PostMapping("/add")
@Transactional
public Map<String, Object> add(HttpServletRequest request) throws IOException {
service.insert(service.readBody(request.getReader()));
return success(1);
}
public Map<String, Object> addMap(Map<String,Object> map){
service.insert(map);
return success(1);
}
删除的代码如下:
@RequestMapping(value = "/del")
@Transactional
public Map<String, Object> del(HttpServletRequest request) {
service.delete(service.readQuery(request), service.readConfig(request));
return success(1);
}
public void delete(Map<String,String> query,Map<String,String> config){
QueryWrapper wrapper = new QueryWrapper<E>();
toWhereWrapper(query, "0".equals(config.get(FindConfig.GROUP_BY)),wrapper);
baseMapper.delete(wrapper);
log.info("[{}] - 删除操作:{}",wrapper.getSqlSelect());
}
管理员可以查看员工考勤列表中某个员工考勤的详情,可以对员工考勤信息进行增删改查操作。其界面如下图4-11所示。
图4-11员工考勤管理界面图
管理员可以查看培训报名列表中某个员工的培训报名详情并提交培训情况信息,可以对培训报名信息进行查询、重置和删除操作。其界面如下图4-12所示。
图4-12培训报名管理界面图
管理员可以查看福利申请列表中某个员工的福利申请详情并进行审核和回复;可以对福利申请信息进行查询、重置、添加和删除操作。其界面如下图4-13所示。
图4-13福利申请管理界面图
管理员可以查看通知公告列表中某一通知公告的详情;可以对通知公告信息进行查询、重置、添加和删除操作。其界面如下图4-14所示。
图4-14通知公告管理界面图
管理员负责对不同的用户角色在访问系统时设置不同的访问权限,避免用户使用超出自己权限的功能。管理员可以查看权限列表中某个用户的权限详情,可以对用户权限进行增删改查操作。其界面如下图4-15所示。
图4-15权限管理界面图
5系统测试
系统测试的目的是确保系统的功能完整、性能稳定,并验证系统是否符合预期的设计和需求。通过系统测试,可以发现和修复潜在的错误和缺陷,提高系统的质量和可靠性。同时,系统测试还可以评估系统在不同条件下的性能表现,包括并发性能、响应时间和容错能力等。通过全面的系统测试,可以确保系统在正式上线前达到高品质的状态。
5.2 测试用例
系统测试包括:用户登录功能测试、通知公告查看功能测试、员工信息添加功能测试、密码修改功能测试,如表5-1、5-2、5-3、5-4所示:
用户登录功能测试:
表5-1 用户登录功能测试表
测试用例编号 | 测试描述 | 预期结果 | 实际结果 | 是否通过 |
TC001 | 使用正确的用户名和密码进行登录 | 成功登录系统,跳转到用户首页 | 登录成功,跳转到用户首页 | 通过 |
TC002 | 使用不存在的用户名进行登录 | 显示错误提示信息:用户名不存在 | 显示错误提示信息:用户名不存在 | 通过 |
TC003 | 使用正确的用户名和错误的密码进行登录 | 显示错误提示信息:密码错误 | 显示错误提示信息:密码错误 | 通过 |
TC004 | 不输入用户名和密码直接点击登录按钮 | 显示错误提示信息:用户名和密码不能为空 | 显示错误提示信息:用户名和密码不能为空 | 通过 |
通知公告查看功能测试:
表5-2 通知公告查看功能测试表
测试用例编号 | 测试描述 | 预期结果 | 实际结果 | 是否通过 |
TC001 | 打开通知公告管理页面,检查是否能够正确展示通知公告列表信息 | 通知公告列表显示正确 | 通知公告列表显示正确 | 通过 |
TC002 | 点击通知公告详情按钮,检查是否能正常打开页面 | 通知公告详情页面显示正确 | 通知公告详情页面显示正确 | 通过 |
TC003 | 检查通知公告查询功能 | 根据公告标题查询到相关通知公告并正确展示 | 根据公告标题查询到相关通知公告并正确展示 | 通过 |
管理员添加员工信息界面测试:
表5-3 管理员添加员工信息界面测试表
测试用例编号 | 测试描述 | 预期结果 | 实际结果 | 是否通过 |
TC001 | 使用合法的信息添加一个新的员工信息 | 员工信息成功添加到系统 | 员工信息成功添加到系统 | 通过 |
TC002 | 使用已存在的员工名称添加一个员工信息 | 显示错误提示信息:员工名称已存在 | 显示错误提示信息:员工名称已存在 | 通过 |
TC003 | 添加员工信息时不输入必填信息 | 显示错误提示信息:必填字段不能为空 | 显示错误提示信息:必填字段不能为空 | 通过 |
TC004 | 使用不存在的关键字进行搜索 | 搜索结果为空 | 搜索结果为空 | 通过 |
表5-4密码修改功能测试表
测试用例编号 | 测试描述 | 预期结果 | 实际结果 | 是否通过 |
TC001 | 输入正确的原密码和新密码进行修改 | 密码成功修改 | 密码成功修改 | 通过 |
TC002 | 输入错误的原密码和新密码进行修改 | 显示错误提示信息:原密码错误 | 显示错误提示信息:原密码错误 | 通过 |
TC003 | 不输入原密码和新密码直接点击修改按钮 | 显示错误提示信息:密码不能为空 | 显示错误提示信息:密码不能为空 | 通过 |
5.3 测试结果
通过编写基于Spring Boot的医院人事管理系统的测试用例,已经检测完毕系统测试包括:用户登录功能测试、通知公告查看功能测试、员工信息添加功能测试、密码修改功能测试,通过这四大模块为基于Spring Boot的医院人事管理系统的设计与实现的后期推广运营提供了强力的技术支撑。
在基于Spring Boot的医院人事管理系统开发之前,需要先对用户的具体需求进行分析。包括系统的可行性分析、功能需求分析以及其他需求等。在可行性分析过程中,对系统实现的技术性、经济性等方面进行了分析。总体上证明了系统实施的可行性。
本文总结了基于Spring Boot的医院人事管理系统开发背景与意义,然后阐述了系统的具体业务需求,并根据系统需求对系统结构以及功能模块等进行了详细地设计,将整个系统划分为多个不同的功能模块。在分析系统功能需求时,对整个系统的总体架构以及功能模块等进行了分析,并选择合适的系统开发技术完成了对各个模块的开发工作。系统开发完成之后进行了部署,同时进行了系统的测试过程,通过测试证明了系统在功能以及性能等方面都达到了预期的要求,具有较高的稳定性与可靠性。
[1]曹灿,吕宜光.基于Java Web的科研院所人事管理系统的设计与实现[J].自动化技术与应用,2023,42(06):131-133.
[2]张汉昌.基于MVVM模式的企业人事管理系统设计与实现[D].西南民族大学,2023.
[3]刘珊,徐先良,郑琪.基于C/S和B/S混合架构的高校人事管理系统设计与实现[J].网络安全和信息化,2023,(05):90-92.
[4]陈立飞,张静,罗召霞.基于B/S模式的人事管理系统的设计与实现[J].信息与电脑(理论版),2022,34(19):140-142.
[5]徐春丽,陈雯,施春雷,等.基于计算机技术的医院人事信息化管理系统研究[J].自动化技术与应用,2022,41(05):184-186.
[6]周兴权.“互联网+”背景下医院人事管理信息化研究[J].黑龙江人力资源和社会保障,2022,(08):92-94.
[7]胡金梅,胡金萍.基于Web的公司人事管理系统设计[J].无线互联科技,2022,19(06):59-60.
[8]张军.基于Java的企业人力资源管理系统的设计与实现[J].中国信息化,2022,(03):42-44.
[9]亓望,杨洁,刘宏伟.医院人事信息管理系统运行现状及改进对策研究[J].现代信息科技,2021,5(20):143-145+149.
[10]王强.大数据时代医院人事管理创新研究[J].办公室业务,2021,(07):151-152.
[11]刘东升,陈春萍,梁惠兰.互联网大数据时代下医院人事管理创新效果研究[J].智慧健康,2021,7(10):17-19.
[12]李娜,雷含川,邹蜜.“互联网+”环境下医院人事档案管理策略探讨[J].商业文化,2021,(04):98-99.
[13]李红娟.探析医院人事管理新对策[J].人力资源,2021,(02):16-17.
[14]胡金宇.基于Spring Boot和Vue框架的企业绩效考核系统设计与实现[D].湖北师范大学,2023.
[15]张文.基于SpringBoot的国有企业固定资产信息管理系统的设计与实现[D].华东师范大学,2023.
[16]金斗.Web应用高并发下的负载均衡研究与优化[D].长江大学,2022.
[17]Liang C .School Vehicle Management System Based on JAVA Language[J].Academic Journal of Computing Information Science,2023,6(9):
[18]Yang Y .Design and Implementation of Student Information Management System Based on Springboot[J].Advances in Computer, Signals and Systems,2022,6(6):
[19]Sunday O B ,Nduka O S . MySQL Database Server: Deploying Software Application to Enhance Visibility and Accountability [J]. Current Journal of Applied Science and Technology, 2023, 42 (4): 16-23.
[20]熊群毓.大数据时代MySQL数据库的应用分析[J].信息与电脑(理论版),2023,35(14):209-212.
首先,我要感谢我的论文指导老师。在论文完成的整个过程中,指导老师始终给予我无微不至的关爱与指导。在论文写作的过程中,导师那耐心细致的指导,以及提出的具有建设性的意见,都给予了我极大的帮助,让我受益匪浅。导师严谨的治学态度、敬业精神以及高水平的教学能力,都给我树立了追求卓越的典范,这对我以后的人生道路和学业成就都产生了极大的积极影响。
此外,我还要感谢我班的同学们,他们既是我的同窗好友,又是我的良师益友。正是由于你们的支持和关怀,使得我在大学期间的学习和生活都变得异常充实。感谢那些在大学期间给予我帮助的所有老师和同学们,是你们给予了我在学业道路上的前进动力。
当然,我也不能忘记我的父母,是他们用无私的爱抚养我成人。你们的养育之恩我将永生难忘,将来我一定会用我的成绩回报你们。在成长的道路上,我会不断努力,不负众望,用实际行动来回报你们对我的期望。
免费领取项目源码,请关注❥点赞收藏并私信博主,谢谢~