湖南科技大学数据库课设(工资管理系统)

目录

一、 课程设计题目

二、 课程设计目的

三、总体设计

三、 详细设计

四、 结果与分析

工资管理系统

一、课程设计题目

工资管理系统:工资管理系统用于每个月员工实发工资的计算,计算的项目包括基本工资、奖金、福利、 津贴等。

二、课程设计目的

数据库系统课程设计是为了配合学习数据库系统原理及应用开发而设置的,是计算机科学与技术、大数据、信息安全、物联网工程、软件工程、智能制造等专业集中实践的教学环节,是将关系数据库理论知识转化为解决实际问题能力的重要环节。数据库系统课程设计目的在于加深对关系数据库理论知识的理解,通过使用具体的 DBMS,掌握一种实际的数据库管理系统并掌握其操作技术,熟练掌握使用数据库前端开发工具(如 VB、C++、Java、JSP、Delphi、PowerBuilder 等),进一步提高同学们运用数据库技术解决实际问题的能力。

**三、**总体设计

*基本原理*****:****本课设用到有Java,JDBC操作,数据库的增删改查,数据库系统的设计等方面的基本知识。用Java的GUI显示页面,将其提供给用户使用,通过JDBC连接数据库,使得用户对界面的操作转化成对数据库的表的操作,数据库将数据进行存储,要用到的时候就从数据库里面读出。本系统我将系统分成了三个大的模块,一个是GUI界面展示区,一个是对传输的参数进行封装的Model区,还有一个是将界面上的操作转化成对数据库界面操作的Dao区。

****模块介绍:****本系统分为了两个大的模块,分别为员工的信息资料工资模块,管理员的管理模块,管理员模块又分成了九个小小的模块,分别是员工基本工资设置、奖金设置、津贴福利设置、扣发设置、工资设置表、其他工资项目表、月度考勤统计表、部门信息表、月度工资统计表。员工和管理员的主功能区如下图所示。

image-20231115102652543

image-20231115102747060

设计步骤:

1、以指导书中的业务描述为基础,通过检索资料与图书阅读调查与分析系统的业务需求,明确系统的功能与非功能需求。

2、通过对用户需求进行综合、归纳与抽象,形成一个独立于具体DBMS的概念模型,可以用E-R图表示。

3、将E-R图转化成关系模型,根据模型,建立数据里面的表。

4、进行系统的实现,实现用户操作,将用户操作转化成对数据库数据的增删改查。

四、详细设计

1 系统需求分析
1.1 系统功能分析

本系统主要有以下几项功能:

Ø 员工基本工资的设定。

Ø 奖金以及福利补贴的设置。

Ø 实发工资计算公式的调整。

Ø 根据出勤统计结果计算本月各项实际余额。

Ø 输出工资报表。

1.2 系统功能模块设计(划分)

根据系统功能要求,可以将系统分解成几个模块来分别设计

应用程序界面,如图 1 所示。

image-20231115102818477

图1工资管理系统功能模块图

1.3 与其它系统的关系

工资管理系统的输出结果是对员工工作的一个评价。本系统中,计算工资的基本依据是考勤管理系统的统计结果。同时,在统计和查询时需要用到人事管理系统中员工信息和部门信息。

1.4 数据流程图

工资管理系统的数据流程如图 2 所示。

image-20231115102839201

图 2、工资管理系统数据流程图

2 数据库设计
2.1 数据库需求分析

根据上面的数据流程图,可以列出以下系统所需的数据项和数据结构:

l 员工工资设置;员工号、工资(元小时)。

l 福利津贴扣发:记录编号、年月、员工号、类别、项目名称、金额、说明。

l 月度工资统计:记录编号、年月、员工号、基本工资、奖金、其他应发明细、其他

应发总额、扣发明细、扣发总额、实发金额。

所需的外部数据支持:

l 人员信息:员工号、密码、权限、姓名、部门、当前状态等。

l 部门设置:部门编号、名称等。

l 月度考勤统计:记录号、员工、年月、各类统计信息。

2.2 数据库概念结构设计

图 3 是本系统所需数据的 E-R 模型图。

image-20231115102934598

图 3、工资管理系统的 E-R 图

2.3 数据库逻辑结构设计

本系统总共涉及 7 个数据表。其中 3 个表用于保存员工信息、部门设置和考勤统计,可以使用人事管理系统和员工考勤系统中建立的数据表。另外需要建立 3 个数据表用于保存工 资设置、福利津贴扣发记录和工资统计结果。另外福利津贴扣发记录中,需要用到 1 个记录 类别代码表,用于标识记录数据福利津贴还是扣发项。这 7 个需要建立的数据表结构如下所示。

PERSON员工个人信息表
字段名数据类型是否可空说明
IDchar员工号(主关键字)
PASSWDchar密码
AUTHORITYchar用户权限
NAMEchar姓名
SEXchar性别
BIRTHDAYchar生日
DEPARTMENTchar所在部门
JOBchar职务
EDU_LEVELchar受教育程度
SPECIATYchar专业技能
ADDRESSchar家庭住址
TELchar联系电话
EMAILchar电子信箱
STATEchar当前状态(T-员工,F-非员工)
REMARKchar备注
DEPARTMENT部门信息表
字段名数据类型是否可空说明
IDint部门编号
NAMEchar部门名称
MANAGERchar部门经理
INTROchar简介
ATTENDANCE_STATE 月度考勤统计表
字段名数据类型是否可空说明
AR_MONTHint统计月份
PERSONchar员工号
WORK_HOURint累计工作时间
OVER_HOURint累计加班时间
LEAVE_HDAYint累计请假时间(半天)
ERRAND_HADYint累计出差时间(半天)
LATE_TIMESint迟到次数
EARLY_TIMESint早退次数
ABSENT_TIMESint旷工次数
SALAY_OTHER其他工资项目表
字段名数据类型是否可空说明
IDint记录编号(主关键字)
YEAR_MONTHint年月
PERSONchar员工号
TYPEint类型
NAMEchar名称
MONEYchar金额
DESCRIPTIONchar具体描述
SALARY月度工资统计表
字段名数据类型是否可空说明
IDint记录编号(主关键字)
YEARMONTHint年月
PERSONchar员工号
BASICint基本工资
BONUSint奖金
ADD_DETAILchar其他应发明细表
ADD_TOTAILint其他应发总额
SUB_DETAILchar扣发明细表
SUB_TOTALint扣发总额
TOTALint实发金额
SALARY_SET工资设置表
字段名数据类型是否可空说明
PERSONchar员工号(主关键字)
SALARYint工资(元/小时)
TYPE类型代码表
字段名数据类型是否可空说明
CODEint代码(主关键字)
DESCRIPTIONchar说明
2.4 数据库的建立

2.4.1 数据库的建立

建立数据库所用到的sql语句如下:

image-20231115103012810

2.4.2 初始数据的输入

这里我先放入数据在信息表、出勤表、部门信息表、类型代码表等表中。具体情况如下图所示。

image-20231115103028310

3 各功能模块的设计与实现
3.1 功能说明

1、员工基本工资的设定。

2、奖金以及福利补贴的设置。

3、实发工资计算公式的调整。

4、根据出勤统计结果计算本月各项实际余额。

5、输出工资报表。

3.2 用户界面设计

完成数据库创建和功能说明以后,我可以进行下一步工作,即设计用户界面。我把工资管理系统的窗体分成一下7个主要部分。附加一些部门信息查询界面等等。

1、管理员主窗口设计

2、员工基本工资设定界面设计

3、奖金以及福利补贴设置界面设计

4、实发工资计算公式调整界面设计

5、计算本月各项实际余额界面设计

6、工资报表设计

image-20231115103108207

7、员工个人信息以及工资界面

image-20231115103125485

所有界面展示图如下图:

image-20231115103146160

imgimage-20231115103213375image-20231115103237869image-20231115103250959

img

img

image-20231115103332324

对于界面展示效果设计,这里以员工页面进行说明。

image-20231115103402292

这里是构造一个类继承JFame类,通过.setBounds()方法设置窗口的位置大小,通过.setVisible()设置窗口的可见性,设置为true为可见用.setDefaultCloseOperation()方法设置窗口的关闭事件,否则点击窗口的关闭按钮并不能关闭窗口。然后使用.setResizable()方法设置窗口大小的不可变性,使用.setLayout()方法设置窗口的布局,这里由于我用的是觉得定位,就将参数设置为null。到这里一个可以展示的窗口就已经设置完成,接下来就是往窗口里面添加不同的组件,给不同的组件添加不同的监听事件。

对于此次系统我使用的都是一些简单的组件例如,Jtable、Jbutton、JTextFiled等等,通过使用组件本身自带的方法设置组件的属性,样式,从而满足需求,对于美观没有做较高的要求。

3.3 各功能模块的实现

*1**、员工基本工资设定的实现。*

image-20231115103532851

image-20231115103542045

image-20231115103555282

2、

*奖金以及福利补贴设置的实现。*

image-20231115103611344

image-20231115103629195员工的福利津贴全部设置在salary表的其他总和里面,设置了津贴和福利之后,其他工资表里面的项目也会跟着一起改变。改变的原理是,在原有基础上将后面设置的津贴福利往后面添加。奖金的设置界面有一个显示员工出勤数据的表格,作为奖金设置的依据,对于津贴福利,没有给出具体的发放依据,因此界面设计的比较简单。

3、*实发工资计算公式调整的实现。*

对于实发工资计算公式的调整,我这里采用的是对于工资有个基本工资之外,还有个工资项目是根据员工的工作时长乘以工作一个小时的工资得到,在工资报表中也属于其他应发工资那一栏。对于不同员工不同职务,不同人工作一个小时的工资不一样。然后其他应发工资的求和也和福利津贴是一样的,设置之后,在原来基础上再加上新设置的。由于代码和上一步代码差别不大,这里就不再展示了。

4、*根据出勤统计结果计算本月各项实际余额的实现。*

image-20231115103734367 界面设置的比较简单,对于所有员工都是一样的规矩,点击确认的时候,会自动计算应该扣除的工资,将扣除的工资写入其他工资项目表,和总的工资报表里面的其他扣除工资的总和。具体代码实现如下:

image-20231115103832511

image-20231115103744688

*5**、输出工资报表的实现。*

输出工资报表,我就是放了一个简单的表,然后可以通过员工的编号和月份进行查询员工某月的工资报告,对于总的工资的计算我是放在该页面,只有打开该页面,员工总工资的计算才会发生,计算结果才会写入数据库,核心代码如下:

image-20231115103910774

image-20231115103923915

五、结果与分析

本系统能实现工资发放等问题,能实现基本工资的设置,计算公式的调整,工资报表,其他工资设置,其他工资项目统计表等问题。员工也能实现工资系统里面个人部分信息的修改,密码修改等等。系统也能对登录的人员进行身份的认定,放置非管理员使用管理员权限。该系统的功能分布比较细,没有将所有功能杂糅在一个界面里面,造成视觉疲劳。使用的组件比较简单常用,出错的概率小。

对于结果的展示都是选择直接从数据库里面读出数据,不是中间数据的展示,避免了数据的丢失等问题。

对于查询操作,这里展示两张查询结果图。

image-20231115104016233

image-20231115104026394

  • 2
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
湖南科技大学数据库课程设计的企业内部行文管理系统是一个用于管理和组织企业内部行文文件的系统。该系统主要包括行文文件的创建、管理、审批、归档等功能,旨在提高企业内部行文管理的效率和便捷性。 该系统的数据库设计主要涉及以下几个表:用户表、行文文件表、审批记录表和归档记录表。用户表用于存储系统中的用户信息,包括用户ID、姓名、职位等;行文文件表用于存储行文文件的相关信息,包括文件ID、标题、内容、创建时间等;审批记录表用于记录行文文件的审批流程,包括记录ID、文件ID、审批人、审批意见、审批时间等;归档记录表用于记录已归档的行文文件,包括记录ID、文件ID、归档时间等。 系统的主要功能包括:用户登录、行文文件创建、文件审批、文件归档和文件查询等。用户登录功能用于验证用户身份,并根据用户的权限来显示相应的功能菜单;行文文件创建功能用于创建新的行文文件,并将其存储到数据库中;文件审批功能用于对行文文件进行审批操作,包括审批意见的填写和审批记录的保存;文件归档功能用于将已审批通过的行文文件进行归档操作,将其移动到归档记录表中;文件查询功能用于根据条件查找和筛选已创建、审批和归档的行文文件。 该系统的java代码可以通过使用Java编程语言和MySQL数据库来实现。可以使用Java的GUI界面框架(如Swing或JavaFX)来构建系统的用户界面,并使用MySQL提供的JDBC接口来连接数据库,实现对数据库表的增删改查操作。在编码过程中,需要根据系统需求和设计思路,编写相应的类和方法来实现各个功能的业务逻辑,同时需要注意处理异常和数据校验的问题,确保系统的正常运行和数据的完整性。 总之,湖南科技大学数据库课程设计的企业内部行文管理系统是一个功能完善的系统,通过合理的数据库设计和有效的java代码实现,可以提高企业内部行文管理的效率和规范性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值