工资管理系统实验报告.docx
- 文档编号:730838
- 上传时间:2022-10-12
- 格式:DOCX
- 页数:42
- 大小:594.76KB
工资管理系统实验报告.docx
《工资管理系统实验报告.docx》由会员分享,可在线阅读,更多相关《工资管理系统实验报告.docx(42页珍藏版)》请在冰豆网上搜索。
工资管理系统实验报告
数据库课程设计报告
1.设计目的
数据库原理概述及应用课程设计是软件工程专业集中实践性环节之一,是学习完《数据库原理概述及应用》课程后进行的一次全面的综合练习。
其目的在于加深对数据库基础理论和基本知识的理解,掌握使用数据库进行软件设计的基本方法,提高运用数据库解决实际问题的能力,最终实现对于给定的应用环境,构造最优的数据库模式,建立数据库及其应用系统,使之能够有效地存储数据,满足各种用户的应用需求(信息要求和处理要求)。
同时,此次设计对于同学将来的毕业设计和具体工作实践将有重要的意义。
针对于本次设计的课题工资管理系统,通过E-R图,逻辑结构、物理结构、概念结构三方面分析该系统的实体、属性、以及之间的联系,从各个方面全面了解分析课题,同时,也更掌握了基础知识,深入了解各部分含义。
2.开发环境
SQLServer2005,JDK1.8,EclipseEE版本。
3.系统设计
3.1需求分析
3.1.1数据需求
工资管理系统系是为了更好地实现工资各种信息的管理以及各种信息的安全性管理。
本系统主要对查看员工的各种工资信息需求所设计的,可以很好的管理数据。
本系统的主要功能由以下几个部分组成:
⑴ 系统功能的基本要求:
1员工每个工种基本工资的设定。
2加班津贴管理,根据加班时间和类型给予不同的加班津贴。
3按照不同工种的基本工资情况、员工的考勤情况产生员工的每月的月工资。
4员工年终奖金的生成,员工的年终奖金计算公式=(员工本年度的工资总和+津贴的总和)/12。
5企业工资报表。
能够查询单个员工的工资情况、每个部门的工资情况、按月的工资统计,并能够打印。
6各类单项和多条件组合查询。
7导出查询和统计的结果,形成Excel表。
⑵ 数据库要求:
在数据库中至少应该包含下列数据表:
1员工考勤情况表。
2员工工种情况表,反映员工的工种、等级,基本工资等信息。
3员工津贴信息表,反映员工的加班时间,加班类别、加班天数、津贴情况等。
4员工基本信息表。
5员工月工资表。
3.1.2事物需求
(1)在员工信息管理部分,要求:
A.可以查询员工信息
B.可以对员工信息进行添加删除的操作
(2)在部门信息管理部分,要求:
A.可以查询部门信息
B.可以对部门信息进行添加删除的操作
3.2系统流程图
图3.2系统流程图
4.数据库设计
4.1数据流图
图4.1数据流图
4.2数据字典
4.2.1数据结构描述
名称:
员工
含义说明:
员工信息
组成结构:
员工编号+员工姓名+性别+所属部门+职称
名称:
工资
含义说明:
工资信息
组成结构:
员工编号+基本工资+岗位工资+津贴工资+扣除薪酬+实发工资
名称:
部门
含义说明:
部门信息
组成结构:
部门编号+部门名称+部门人数
4.2.2数据流的描述
数据流名称:
员工信息添加简述:
新员工信息录入
数据流来源:
公司管理者
数据流去向:
员工信息
数据流组成:
员工编号+员工姓名+性别+所属部门+职称
数据流名称:
员工信息修改简述:
员工信息错误或员工调动
数据流来源:
公司管理者
数据流去向:
员工信息
数据流组成:
员工编号+员工姓名+性别+所属部门+职称
数据流名称:
员工信息删除简述:
员工离职
数据流来源:
公司管理者
数据流去向:
员工信息
数据流组成:
员工编号+员工姓名+性别+所属部门+职称
数据流名称:
工资添加简述:
公司对工资进行添加
数据流来源:
公司管理者
数据流去向:
工资信息
数据流组成:
员工编号+基本工资+岗位工资+津贴工资+扣除薪酬+实发工资
数据流名称:
工资修改简述:
公司对工资进行修改
数据流来源:
公司管理者
数据流去向:
工资信息
数据流组成:
员工编号+基本工资+岗位工资+津贴工资+扣除薪酬+实发工资
4.2.3主要数据存储的定义
存储名称:
员工记录
输入:
员工基本信息
输出:
员工所有信息
数据结构:
员工编号+员工姓名+性别+所属部门+职称
存储名称:
部门记录
输入:
部门基本信息
输出:
部门所有信息
数据结构:
部门编号+部门名称+部门人数
存储名称:
工资记录
输入:
员工工资信息
输出:
员工所有工资信息
数据结构:
员工编号+基本工资+岗位工资+津贴工资+扣除薪酬+实发工资
存储名称:
考勤记录
输入:
员工考勤信息
输出:
员工所有考勤信息
数据结构:
员工编号+迟到次数+缺席次数
存储名称:
津贴记录
输入:
员工津贴信息
输出:
员工所有津贴信息
数据结构:
员工编号+加班时间+加班天数+加班类型+津贴资金
4.3概念模型设计(E-R图)
图4.3.1员工信息E-R图
图4.3.2部门信息E-R图
图4.3.3基本工资E-R图
图4.3.4考勤情况E-R图
图4.3.5津贴情况E-R图
图4.3.6工种情况E-R图
图4.3.7月工资信息E-R图
图4.3.8工作管理系统总E-R图
4.4逻辑结构设计
4.4.1关系模式
员工信息(员工编号,员工姓名,性别,所属部门,职称)
部门信息(部门编号,部门名称,部门人数)
基本工资(工资级别,基本工资,岗位工资)
考勤信息(员工编号,迟到次数,缺席次数)
津贴信息(员工编号,加班时间,加班天数,加班类型,津贴资金)
工种情况(工资级别,岗位工资)
工资信息(员工编号,基本工资,岗位工资,津贴工资,扣除薪酬,实发工资)
4.4.2基本表
表1员工基本信息表(dbo.employee)
员工编号
e_id
varchar(8)
主键,不允许重复
员工姓名
e_name
varchar(8)
性别
e_sex
varchar
(2)
所属部门
b_id
varchar(4)
外键
职称
j_name
varchar(12)
表2部门信息表(dbo.brank)
部门编号
b_id
varchar(8)
主键,不允许重复
部门名称
b_name
varchar(20)
部门人数
b_number
int
表3基本工资表(dbo.basesalary)
工资级别
bs_lev
varchar
(2)
主键,不允许重复
基本工资
bs_sal
numeric(8,2)
表4考勤信息表(dbo.check)
员工编号
e_id
varchar(8)
主键,不允许重复
迟到次数
latetimes
numeric(3,0)
缺席次数
offtimes
numeric(3,0)
表5津贴信息表(dbo.bonusinformation)
员工编号
e_id
varchar(8)
主键,不允许重复
加班时间
etr_time
numeric(8,1)
加班天数
etr_day
numeric(2,1)
加班类型
etr_type
varchar(8)
津贴资金
bonus_sal
numeric(8,2)
表6工种情况表(dbo.jobsalary)
工资级别
js_lev
varchar
(2)
主键,不允许重复
岗位工资
js_sal
numeric(8,2)
表7工资信息表(dbo.salaryinfomation)
员工编号
e_id
varchar(8)
主键,不允许重复;外键
基本工资
bs_sal
numeric(8,2)
岗位工资
js_sal
numeric(8,2)
津贴工资
bonus_sal
numeric(8,2)
扣除薪酬
check_sal
numeric(8,2)
实发工资
get_sal
numeric(8,2)
5.应用程序设计
5.1主窗体模块
进入登陆页面,如下图:
图5.1.1登录
登陆后进入系统主界面,如下图:
图5.1.2系统主界面
5.2员工信息模块
(1)查询,分别点击“编辑”“删除”按钮可修改、删除员工信息,如下图:
图5.2.1查询修改员工信息
图5.2.2修改员工信息
5.3部门信息模块
(1)查询.删除所有部门信息,如下图:
图5.3.1查询删除部门信息
结论
经过两周的不断实践与探索,人力资源-工资管理统的设计与实现己经完成,基本上达到了预期的设计要求和目的。
一个完整的人力资源-工资管理统就创建完毕了。
在本系统的设计与实现的过程中主要讲述了工资管理系统的系统设计部分,包括功能模块设计、数据库结构设计等。
系统设计为整个程序构建了骨架,各个功能模块实现各个细节部分。
系统的详细设计根据系统分析阶段的结论将系统具体化,并完成了各个模块的添加、修改、删除与查询的功能,直到最后形成一个完整的可行性的管理系统。
在整个设计阶段的工作和本实验报告的写作过程的经历将会使我们小组终生受益,并对我们今后的工作和发展产生深远的影响。
由于设计时间比较仓促,所以该系统还有许多不尽如意的地方,比如用户界面不够美观,出错处理不够等多方面问题。
这些都有待于进一步的改善。
参考文献
1.《数据库原理概述及应用》,作者是魏善沛,张艳。
2.《JSP实用教程》清华大学出版社。
3.访问的链接:
附录A(源代码)
SQL亮点语句:
1)--双重左外连接,员工表数据全查出
selectemployee.e_id,employee.e_name,employee.e_sex,branch.b_name,employee.j_name,bs_lev,bonus_sal
from(employeeleftjoinbranchonemployee.b_id=branch.b_id)leftjoinbonusinformationonemployee.e_id=bonusinformation.e_id
2)创建触发器
createtriggerdepartment_person--创建触发器
onemployee--监听员工表的增删,自动更新部门表的人数
forinsert,delete--监听employee表的增删操作
as
updatebranchsetb_number=b_number+1
whereb_id=(selectb_idfrominserted)
updatebranchsetb_number=b_number-1
whereb_id=(selectb_idfromdeleted)
Go
3)设置津贴默认值
altertablebonusinformation--津贴默认0
addconstraintdefault_bonusdefault0forbonus_sal
4)创建触发器
ALTERtriggeradd_checkSal--创建触发器
oncheckTime
forinsert,update--监听
as
u
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 工资管理 系统 实验 报告