数据库课程设计——工资管理系统Qt

引言

近年来,随着我国信息技术的飞速发展,计算机应用已逐渐渗透到各个领域。在企业管理领域内,计算机的应用已经十分广泛,各种管理机制与企业运作流程都与计算机紧密结合在一起,计算机的应用进一步完善了企业的管理,提高了企业的现代化管理形象。开发职工工资管理系统的目的就是为了帮助财务部门能更好地管理本单位的职工工资,提高工作效率,实现职工工资信息管理的规范化和自动化。
本文的目的是设计一款工资管理系统,旨在提高工资管理效率,减少人工管理成本。本报告将从需求分析、系统架构设计、系统实现以及测试等方面详细介绍此工资管理系统的设计及实现过程。通过本系统的设计与使用,企业可以更加方便地实现工资的管理、计算和发放,提升管理效率,降低管理成本。

一、概述

本员工工资管理系统实现了对员工工资信息的浏览、删除、修改、查询和统计分析功能,节省了大量的人工操作的工作量,自动完成众多的信息处理,减少了数据出错的几率,加强了工资记录的安全性和完整性。其主要系统功能包括以下几个模块:系统模块管理(包括登录、用户管理)、员工管理(包括添加新员工信息、员工信息查询、员工信息维护)、工资组成项目(包括工资信息的添加、工资信息维护)、员工工资的统计分析等。清晰的体现了员工工资管理流程,完成了基本的员工工资管理要求,是一个典型的信息管理系统。该系统大大地简化了操作流程,提高了企业的工作效率。

二、需求分析

2.1功能定义
工资管理系统应完成以下功能:
(1) 管理员通过账号密码登录。
(2) 员工信息管理: 实现对员工信息的输入、查询和修改(如员工编号、部门、姓名、性别、联系方式、入职时间、任职状态)。
(3) 部门信息管理:实现对部门信息的输入、查询和修改(如部门编号、部门名称、部门经理、部门电话、部门邮箱)。
(4) 工资管理:员工工资一部分是基本工资,根据员工的工龄和岗位设置;另一部分根据每月到岗天数,决定是否有扣除工资。包括对工资的查询和修改。(职工号、年月、基本工资、补贴工资、扣除工资、应发工资、实发工资、发放状态)。
(5) 考勤管理:记录每个月员工到岗天数、请假天数。(职工号、年月、出勤天数、请假天数)。
(6) 统计分析功能:统计当月所要核发的工资总金额,平均工资,以及最高和最低工资。
工资规定
基本工资:4k
工资=基本工资+岗位补贴+工龄补贴-扣除工资

岗位补贴表:

岗位人事部 市场部 服务部设计部 技术部 生产部客户部 售后部运营部 销售部财务部
补贴800200020020001500

缺勤:员工缺勤为-100元/天。
工龄补贴表:

工龄不满1年1年2年3年3年以上
工龄补贴+0%2%5%8%15%

图 1 工资管理系统
在这里插入图片描述
2.2参与者
(1) 系统管理员:
① 对员工信息的管理,包括对员工信息的输入、查询、修改的信息。
② 对部门信息的管理,包括对部门信息的输入,查询、修改的信息。
③ 根据员工的岗位补贴、工龄补贴、每日考勤,完成工资的核算并发放工 资。
④ 统计分析当月所要核发的工资总金额,以及最大和最低工资金额。
2.3 用例图
(1) 系统管理员用例图
在这里插入图片描述

                                                  图 2 系统管理员用例图

(2) 工资管理系统用例图
在这里插入图片描述

                             图 3 工资管理系统用例图

三、概念结构设计

工资管理系统涉及的实体有:
 职工:属性有员工编号、姓名、性别、联系方式、入职时间、任职状态。
 部门:部门编号、部门名称、部门经理、部门电话、部门邮箱、部门地址。
 工资:年月、基本工资、补贴工资、扣除工资、应发工资、实发工资、发放状态。
 考勤:年月、出勤天数、请假天数。
实体之间联系如下:
(1) 一个部门可以存在多名员工,一个员工只能在一个部门工作。
(2) 一个职工每个月拥有一份工资,并且存在一份考勤记录。

四、逻辑结构设计

在这里插入图片描述
图 8 工资管理系统ER图

五、物理结构设计

为了提高系统的性能,根据应用情况将数据的易变部分与稳定部分、经常存取部分与不经常存取部分分开存放。由于现在的计算机都有多个磁盘,将表(如员工信息表)和索引放在不同的磁盘上,在查询过程中,大大提高I/0读写的效率,而对于较大的分放在两个磁盘上,可以加快存取速度,在多用户环境下的作用更有效;为了改进系统﹑的性能,将日志文件与数据库对象(表、索引等)放在了不同的盘上。同时,考虑到本系统是多用户的,为了提高效率,数据库备份的数据和日志文件将保﹑存在磁盘中。在数据库中经常存取的部分包括:
工资(职工编号、年月、基本工资、应发工资、实发工资、扣除薪资、补贴薪资、发放状态);
职工(职工编号、部门编号、姓名、性别、入职日期、联系方式、任职状态);
考勤(职工编号、年月、出勤天数、请假天数);
部门(部门编号、部门名称、部门经理、部门电话、部门邮箱、部门地址、基本工资);
在数据库设计初始阶段,为了对以后的数据库进行物理优化,提供了一些系统配置变量、存储分配系数,并对这些变量赋予合理的缺省值。但这些值不一定适合每一种应用环境,在进行物理设计时,对这些变量重新赋值,以改善系统的性能。在选择硬件设备、服务器操作系统应该考虑能够逐步增加和扩展。在配置系统变量时,要注意同时使用数据库的用户数,同时打开的数据库﹑对象数,内存分配参数,缓冲区分配参数,时间片大小,数据库的大小,锁的数目等。这些参数值都会影响数据库的存储时间和存储空间的分配。

六、数据库设计

6.1数据库完整性设计
(1)	实体完整性
员工表:员工编号为主键,此项非空且唯一。
部门表:部门编号为主键,此项非空且唯一。
工资表:员工编号、年份、月份为主键,此项非空且唯一。
考勤表:员工编号、年份、月份为主键,此项非空且唯一。
(2)	参照完整性
员工表:
FOREIGN KEY(部门编号) REFERENCES 部门(部门编号)
工资表:
FOREIGN KEY(员工编号) REFERENCES 员工(员工编号)
考勤表:
FOREIGN KEY(员工编号) REFERENCES 员工(员工编号)
(3)	用户定义完整性
① 员工表:
姓名(非空):
ename VARCHAR(50) not NULL
性别(只允许取‘男’或‘女’):
Ssex VARCHAR(4) CHECK (Ssex IN('男','女'))
年龄(年龄只允许大于等于18岁):
Sage Smallint CHECK(Sage>18)
联系方式(取值唯一): 
phone_number VARCHAR(20) UNIQUE  
入职时间(入职时间仅限2015-2099):
hire_date INT CHECK(hire_date>=2015 AND hire_date<2099)
在职状态(只允许取‘在职’或‘退休’):
employment_status VARCHAR(50) 
CHECK (employment_status IN('在职','退休'))
money int NOT NULL
② 工资表
年份(限于2015-2099之间)  
year INT check(year BETWEEN 2015 AND 2099)
月份(限于1-12之间)  
month INT CHECK(month BETWEEN 1 AND 12)

七、数据库运行与维护


7.1创建数据库
    CREATE DATABASE dataystem;
7.2创建数据表
   部门信息表的建立:
CREATE TABLE department(
       dno VARCHAR(8) PRIMARY KEY,    -- 部门编号
       dname VARCHAR(20) NOT NULL,    -- 部门名称
       dmanger VARCHAR(20) ,    -- 部门经理
       dphone VARCHAR(15) UNIQUE,    -- 部门电话
       demail VARCHAR(30) NOT NULL,    -- 部门邮箱
       daddress VARCHAR(100),   -- 部门地址
	   money int -- 基本工资
);
   职工信息表的建立:
CREATE TABLE employee (  
  employee_id CHAR(6) PRIMARY KEY, -- 员工编号
  dno VARCHAR(8),  --  部门编号
  ename VARCHAR(50) not NULL, -- 姓名
  Ssex VARCHAR(4) CHECK (Ssex IN('男','女')), -- 性别
  Sage Smallint CHECK(Sage>18),-- 年龄
  phone_number VARCHAR(20) UNIQUE, -- 联系方式
  hire_date INT CHECK(hire_date>=2015 AND hire_date<2099), -- 入职时间
  employment_status VARCHAR(50) 
CHECK (employment_status IN('在职','退休')),-- 在职状态
FOREIGN KEY(dno) REFERENCES department(dno)
);
员工工资表的建立:
CREATE TABLE salary (
  employee_id CHAR(6) NOT NULL, -- 员工编号
  year INT check(year BETWEEN 2015 AND 2099),        -- 年份
  month INT CHECK(month BETWEEN 1 AND 12),       -- 月份
  basic_pay INT, -- 基本工资
  butie_pay INT,  -- 应发工资
  kouchu_pay INT,    -- 实发工资
  yingfa_pay INT,  -- 扣除工资
  shifa_pay INT, -- 补贴工资
  s_status CHAR(6) NOT NULL,   -- 发放状态
  PRIMARY KEY (employee_id, year, month)
);
员工考勤表的建立:
CREATE TABLE attendance (
  employee_id CHAR(6), -- 职工号,唯一标识
  year INT NOT NULL, -- 年份
  month INT NOT NULL, --  月份
  attendance_days INT NOT NULL, -- 出勤天
  leave_days INT NOT NULL , --  请假天
	PRIMARY KEY (employee_id, year, month)
);
管理员登录表的建立:
CREATE TABLE user (
    username VARCHAR(255) NOT NULL,
    password VARCHAR(255) NOT NULL
);
7.3创建视图
创建查询指定部门编号员工信息:
CREATE VIEW employee_department_salary AS
SELECT e.employee_id, e.ename, d.dname, e.Sage, d.money
FROM employee e
JOIN department d ON e.dno = d.dno
WHERE e.dno = '指定部门编号';**

八、系统功能实现

8.1 工资管理系统界面设计
工资管理系统主要分为左右两部分,左侧为导航栏,主要分为员工信息管理、部门信息管理、工资管理、考勤管理、数据分析五个板块。通过点击不同的板块内容,实现不同的功能。
在这里插入图片描述

                          图8-1 工资管理系统系统界面设计

8.2员工信息管理界面设计
点击员工信息按钮,即可显示出公司内部所有员工信息,通过界面配置的搜索框、编辑、删除、新增、保存等按钮即可对员工信息进行操作。
在这里插入图片描述

                                                        图8-2 员工信息管理界面

8.3部门信息管理界面设计
点击部门信息按钮,即可显示出公司内部所有部门信息,通过界面配置的搜索框、编辑、删除、新增、保存等按钮即可对部门信息进行操作。
在这里插入图片描述

                                                   图8-3 部门信息管理界面

8.4工资管理界面设计
点击工资管理按钮,即可显示出公司内部所有员工工资信息,通过界面配置的搜索框、编辑、删除、新增、保存等按钮即可对工资信息进行查询,修改、删除、添加等操作。
在这里插入图片描述

                              图8-4 工资管理界面

8.5考勤管理界面设计
点击考勤管理按钮,即可显示出公司内部所有员工考勤信息,通过界面配置的搜索框、编辑、删除、新增、保存等按钮即可对考勤信息进行查询,修改、删除、添加等操作。
在这里插入图片描述

                                                           图8-5 考勤管理界面

8.6数据分析界面设计
通过数据库操作计算部门工资分布,部门人数分布,以及部门工资分布,来实现数据分析操作。
在这里插入图片描述

                               图8-6 数据分析界面

九、总结

Qt连接数据库MySQL方法请参考如下连接:
Qt连接数据库解决办法

  • 65
    点赞
  • 341
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 32
    评论
人事工资管理系统 1问题描述 1.1设计目的 本系统的设计目标是能够对该公司的员工的基本信息和工资信息进行添加和修改 ,根据个人信息将工资分为职务工资,职称工资和其他工资.能够调整工资标准和员 工信息,也能够调整其他工资项目,根据需要对教职员工基本信息和工资信息的查询 ,系统应该包括系统用户数据的添加,修改和删除。系统应该具有简单,易用,小巧 ,经典的特色,应该能够对高校工资管理进行优化,使其系统化,高效化,智能化。 并保证工资管理的准确性,简易性,为公司财务人员提供便利。 1.2设计背景 随着市场经济的快速发展,公司规模越来越大,员工的数量也越来越多,员工工 资管理更加的复杂,而工资管理是一项琐碎、复杂而又十分细致的工作,工资计算、 发放、核算的工作量很大,一般不允许出错,如果实行手工操作,每月发放工资须手 工填制大量的表格,这就会耗费工作人员大量的时间和精力,计算机进行工资发放工 作,不仅能够保证工资核算准确无误、快速输出,而且还可以利用计算机对有关工资 的各种信息进行统计,服务于财务部门其他方面的核算和财务处理,同时计算机具有 着手工管理所无法比拟的优点。例如:检索迅速、查找方便、可靠性高、存储量大、 保密性好、寿命长、成本低等。这些优点能够极大地提高人事工资资管理的效率,也 是企业的科学化、正规化管理,与世界接轨的重要条件。这就对人事工资管理提出了 新的要求,用计算机管理系统来管理高校工资已经成为目前的趋势,使用计算机可以 高速,快捷地完成以上工作。在计算机联网后,数据在网上传递,可以实现数据共享, 避免重复劳动,规范数据管理行为,从而提高了管理效率和水平。人事工资管理系统 便是以计算机为工具,通过对工资管理所需的信息管理,不仅把管理人员从繁琐的数 据计算处理中解脱出来,而且优化了管理体系,使其高效化,简易化,智能化,也提高 了透明度和互动性. 2系统目标和建设原则 2.1系统目标 某公司决定建立"工资管理系统",以取代单一的人工管理。根据人员基本情况表 中的职位、职称及工龄长短,决定工资表中的基本工资和岗位津贴的具体数值。根据 各部门上报的扣款表的内容决定工资表中扣款项的金额.按月汇总工资表。 2.2建设原则 根据我们确定的工资数据库的设计思想,我们提出我建设原则如下: A.高可靠性: 该系统是该公司进行工资管理、员工信息管理、日常行政管理和奖惩管理 的基础设施,要求有很高的可靠性,以此建立起稳定、实用的应用环境,因此系 统方案设计就以高可靠性为首要原则。 B.安全性: 系统平台和系统平台数据的安- —对网络系统应严格地管理,并通过防火墙和有效设置权限等方法加强系统平台 和数据的安全。 C.实用性: 选择适合公司应用规模和层次的技术,需求操作平台充分考虑其性价比和 适用性,网络管理简单方便、可维护性强,以降低系统管理、运行、维护和升 级费用,增强可使用性。 D.规范、开放:   坚持开放性和标准化原则,采用的各种系统平台、协议、技术、开发工具、 应用系统是开放的、标准化的和可维护的。 3运行环境规划 选择微软平台作为主导,一方面考虑目前微软的飞速发展,越来越多的企业在规 划内部网络时,将微软平台作为首选方案;另一方面从技术角度来讲,微软平台上的 应用无论是在开发上,还是在软件的部署上都非常容易,而且性能优越. A.开发工具与语言:visual basic 6。0 B.中文版硬件环境:CPU型号为Pentium 以上,内存128M以上。 C.系统环境:Linux及Windows98以上系统均可。 D.DBMS开发工具:MS SQL Server 2005 4需求分析说明 4。1功能需求描述 A.员工基本信息模块 员工基本信息模块具有员工信息输入、员工增删、员工信息查询三个功能,员工基 本信息包括员工号、员工姓名、员工性别、所在职位、具体职称、工龄和工资等级等 信息。员工增删实现了对数据库中员工信息的增加和删除。员工可以通过员工号或员 工姓名对员工信息进行查询。 B.工资结构设置模块 根据该公司的工资管理实际情况,本系统将工资结构分为职位工资、职称工资、 工龄工资、其他工资四部分.该模块可以对这四个工资类型设置工资等级,并对每个等 级设置工资标准. C.工资汇总模块 用户在员工信息管理模块对该员工的工资等级进行输入以后,在工资汇总模块会自 动对员工工资进行汇总。用户可以打印出工资汇总表,打印之前可以通过打印预览功 能进行打预览。 以下便是该系统的功能模块示意图: 图4.2人事工资管理系统功能模块结构图 4。3数据库设计 4。3.1数据库介绍 所谓数据库(Database)就是指按一定组织方式存储在一起的,相互有关的若 干个数据的结合,数据库管理系统(database Management System)就是一种操纵和管理
对于Qt和SQLite数据库课程设计,你可以考虑以下步骤和内容: 1. 确定需求:首先确定你的课程设计目标和要求,例如设计一个简单的图书管理系统或学生信息管理系统。 2. 学习Qt和SQLite:掌握Qt框架和SQLite数据库的基本知识,包括Qt的界面设计、信号与槽机制,以及SQLite的基本操作和语法。 3. 创建数据库:使用SQLite命令或Qt提供的API创建一个数据库文件,并设计所需的表结构。例如,可以创建一个图书表或学生表。 4. 编写界面:使用Qt的界面设计器创建用户界面,包括输入框、按钮、列表等控件,以实现对数据库的增删改查操作。你可以根据需求设计适合的界面布局。 5. 数据库操作:使用Qt提供的SQLite API连接到数据库,并编写代码执行基本的数据库操作,如插入、删除、更新和查询数据。 6. 数据展示:在界面上展示数据库中的数据,可以使用列表或表格等控件展示查询结果,并支持排序、过滤等功能。 7. 功能扩展:根据需要,你可以添加其他功能,如导入导出数据、数据统计分析等。这些可根据具体课程设计要求来扩展。 8. 测试和调试:对所实现的功能进行测试和调试,确保软件能够正常运行并符合预期。 9. 文档撰写:撰写课程设计报告,包括项目背景、需求分析、设计思路、代码实现、遇到的问题和解决方案等内容。 希望以上步骤能够帮助到你进行Qt和SQLite数据库课程设计。如果需要更详细的指导,请提供更具体的问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

0000it_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值