✌全网粉丝20W+,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌
文末获取项目下载方式
一、项目背景介绍:
办公自动化(Office Automation,简称OA),是将计算机、通信等现代化技术运用到传统办公方式,进而形成的一种新型办公方式。办公自动化利用现代化设备和信息化技术,代替办公人员传统的部分手动或重复性业务活动,优质而高效地处理办公事务和业务信息,实现对信息资源的高效利用,进而达到提高生产率、辅助决策的目的,最大限度地提高工作效率和质量、改善工作环境
二、项目技术简介:
三、系统功能模块介绍:
四、数据库设计:
1:‘报销管理’(claim)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 主键ID |
emp_id | bigint | NULL | 员工ID |
info | varchar | NULL | 申请理由 |
append_url | varchar | NULL | 附件链接 |
create_time | datetime | NULL | 申请时间 |
total | varchar | NULL | 申请金额 |
status | int | NULL | 状态[0:已提交,1:申请通过,2:申请驳回,3已撤回] |
leave_info | varchar | NULL | 拒绝理由 |
2:‘员工表’(emps)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 主键ID |
name | varchar | NULL | 姓名 |
sex | int | NULL | 性别[0:男,1:女,2:未知] |
birthday | datetime | NULL | 出生日期 |
id_card | varchar | NULL | 身份证号 |
address | varchar | NULL | 家庭住址 |
age | int | NULL | 年龄 |
phone | varchar | NULL | 联系方式 |
work_state | varchar | NULL | 就职状态[0:在职,1:离职] |
join_time | datetime | NULL | 入职时间 |
leave_time | datetime | NULL | 离职时间 |
salary | varchar | NULL | 基本工资 |
create_time | datetime | NULL | 创建时间 |
user_name | varchar | NULL | 账号 |
pass_word | varchar | NULL | 密码 |
img | varchar | NULL | 照片 |
bank_no | varchar | NULL | 银行卡号 |
3:‘员工请假表’(leaves)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 主键ID |
emp_id | bigint | NULL | 员工ID |
start_time | datetime | NULL | 开始时间 |
end_time | datetime | NULL | 结束时间 |
info | text | NULL | 申请理由 |
status | int | NULL | 状态[0:未审批,1:通过,2:拒绝,3:撤回] |
refused_indo | varchar | NULL | 拒绝理由 |
create_time | datetime | NULL | 创建时间 |
4:‘管理员表’(manage)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 主键ID |
user_name | varchar | NULL | 用户名 |
pass_word | varchar | NULL | 密码 |
head_img | varchar | NULL | 头像 |
nick_name | varchar | NULL | 昵称 |
create_time | datetime | NULL | 创建时间 |
5:‘会议表’(meets)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 主键ID |
title | varchar | NULL | 会议标题 |
append_url | varchar | NULL | 附件链接 |
status | int | NULL | 状态[0:未发送,1:已发送] |
create_time | datetime | NULL | 创建时间 |
6:‘通知表’(noticle)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 主键ID |
notice_info | text | NULL | 通知内容 |
title | varchar | NULL | 通知标题 |
create_time | datetime | NULL | 创建时间 |
staus | int | NULL | 状态[0:已发送,1:未发送] |
7:‘打卡表’(punchs)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 主键ID |
emp_id | bigint | NULL | 员工ID |
handle_time | date | NULL | 日期 |
type | int | NULL | 状态[0:正常,1:请假] |
8:‘报告表’(reports)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 主键ID |
emp_id | bigint | NULL | 员工ID |
content | text | NULL | 报告内容 |
type | int | NULL | 类型[0:日报,1:周报,2:月报] |
append_url | varchar | NULL | 附件URL |
create_time | date | NULL | 汇报时间 |
9:‘工资表’(salary)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 主键ID |
emp_id | bigint | NULL | 员工ID |
total | varchar | NULL | 工资总额 |
basic | varchar | NULL | 基本工资 |
with_hold | varchar | NULL | 扣款 |
add_money | varchar | NULL | 其他金额 |
month_time | varchar | NULL | 月份 |
info | varchar | NULL | 说明 |
10:‘员工日程表’(schedules)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | bigint | NULL | 主键ID |
emp_id | bigint | NULL | 员工ID |
content | text | NULL | 日程内容 |
create_time | date | NULL | 创建时间 |
五、功能模块:
考勤模块:员工可通过系统进行每日打卡,请假,请假需要管理员进行审核,管理员可以拒绝亦可以通过,拒绝时可以填写拒绝理由
会议通知模块:管理员可以向员工发布会议通知,以及日常通知,会议通知则可以添加附件,而普通通知则会以markdown的格式向员工进行展示多样化的内容,并且员工可以实时收取到通知
日程模块:员工可以给自己添加每日计划来提醒自己,然后也可以编写日报周报或者年报,管理员则可以查看员工填写的内容
六、代码示例:
@Override
protected void beforeSave(PunchsDTO entity) throws Exception {
String formatNow = LocalDateTimeUtils.formatNow(LocalDateTimeUtils.yyyy_MM_dd);
LambdaQueryWrapper<PunchsDTO> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(PunchsDTO::getHandleTime, formatNow);
List<PunchsDTO> punchsDTOS = this.baseService.list(queryWrapper);
if (CollectionUtil.isNotEmpty(punchsDTOS)) throw new Exception("当日已打卡,不可重复打卡!");
entity.setHandleTime(new Date());
super.beforeSave(entity);
}
/**
* 员工获取会议
*
* @return
*/
@GetMapping("/emp")
public ReturnMsg getEmpNotice() {
LambdaQueryWrapper<MeetsDTO> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(MeetsDTO::getStatus, 1).orderByDesc(MeetsDTO::getCreateTime).last("limit 5");
return ReturnMsg.ok(this.baseService.list(queryWrapper));
}
@GetMapping("/all/emps")
public ReturnMsg allEmps() {
List<BaseSelectEntity> list = new ArrayList<>();
List<EmpsDTO> dtos = empsService.list();
for (EmpsDTO dto : dtos) {
BaseSelectEntity baseSelectEntity = new BaseSelectEntity();
baseSelectEntity.setKey(dto.getId());
baseSelectEntity.setValue(dto.getName());
list.add(baseSelectEntity);
}
return ReturnMsg.ok(list);
}
@GetMapping("/current/{empId}")
public ReturnMsg current(@PathVariable Long empId) {
LambdaQueryWrapper<SchedulesDTO> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(SchedulesDTO::getEmpId,empId).eq(SchedulesDTO::getCreateTime, LocalDateTimeUtils.formatNow(LocalDateTimeUtils.yyyy_MM_dd)).last("limit 1");
return ReturnMsg.ok(baseService.getOne(queryWrapper));
}
七、项目总结:
作为毕业设计,分配给本系统的设计与制作时间还是不足的,所以,OA系统还有许多需要完善的地方。
第一个就是本系统的编程代码问题,各个程序文件的代码存在冗余的地方非常多,导致代码不够简洁,同时对代码的注释也比较麻烦。编码期间,对于很多页面可以共享的函数与方法都没有单独列出来,而是在需要用到函数和方法的页面上都重新编写了代码,通过后期的技术学习,以及对编码过程的分析总结,发现可以把共用的函数或方法编写在同一个页面上,在之后的页面中,需要使用此函数的页面,则可以直接调用函数,无需再编写代码了,这样可以简化代码,也能节省时间和存储空间。
第二个就是对数据库的设计不够好,在数据处理中,影响程序运行速度。因此需要对数据库的性能进行优化。通过这方面知识的学习,在某个开发技术类的博客中,发现可以用数据库连接池技术来解决数据库的性能问题,另外还需规范数据库里面的关系模式,降低数据库的冗余率,提高运行速度。
如果说平时的作业也是检查对知识的掌握情况,那么制作毕业设计,将是对自身所有知识的一个全面检测。因为系统能够制作完成则是经历了很多阶段,正如文中所展示的那样,先有可行性分析,对功能的分析,对功能的设计,对数据库的设计,对程序功能的编码实现,对完成编码程序的测试等,这些环节缺一不可,而且还都需要认真对待,大学学到的所有知识在制作系统时,才会发现不够用。所以这个项目制作,在检测自身能力的同时,也对问题分析,资料搜集,问题解决等能力进行了培养。
八、源码获取:
大家点赞、收藏、关注、评论啦 、查看获取联系方式
链接点击直达:下载链接