工资管理系统的数据库设计
工资管理系统设计
工资管理系统设计2篇工资管理系统设计(一)随着企业规模的不断扩大和工作岗位的不断增加,工资管理对企业来说变得越来越复杂。
为了提高工资管理的效率和准确性,许多企业开始采用工资管理系统来自动化管理工资发放和计算。
本文将介绍工资管理系统的设计与功能,并探讨其对企业的意义。
一、系统设计1. 数据库设计工资管理系统需要一个可靠的数据库来存储员工的个人信息、工作时长、绩效评价等数据。
数据库的设计应考虑数据的安全性、完整性和易用性。
同时,为了提高查询和统计数据的效率,可以采用合适的数据库模型和索引策略。
2. 用户界面设计工资管理系统的用户界面应简洁明了,方便用户操作。
界面应提供员工管理、工资计算、报表生成等功能,使用户能够方便地查看和处理相关信息。
同时,考虑到系统可能需要被不同角色的用户使用,界面设计应根据不同用户的权限进行限制和区分。
3. 流程设计工资管理系统应具备完善的工资计算流程和工资发放流程。
对于计算流程,系统需要根据员工的工作时长、工资标准等因素进行自动计算,并生成工资表;对于发放流程,系统需要提供相应的支付接口和流程,以确保工资能够及时准确地发放给员工。
二、系统功能1. 员工信息管理工资管理系统应能够方便地管理员工的个人信息,包括姓名、工号、职位、部门等。
系统应提供员工信息的录入、修改、查询等功能,以及相应的数据校验和权限控制。
2. 工资计算根据员工的工作时长、加班情况、请假情况等因素,工资管理系统能够自动计算员工的工资,并生成工资表。
系统应支持多种计算方式,如按小时计算、按月计算等,并能够根据不同岗位设置相应的工资标准和计算规则。
3. 报表生成工资管理系统应具备报表生成功能,能够根据需要生成工资汇总表、工资明细表、绩效报告等不同类型的报表。
报表应具备灵活的设置选项,能够按照部门、岗位、时间段等条件进行筛选和排序,以满足不同用户的需求。
4. 权限管理工资管理系统应具备完善的权限管理功能,以保证数据的安全性和机密性。
员工工资管理系统_数据库课程设计
企业员工工资管理系统设计1一、背景 .........................................................1二、员工工资系统设计 ............................................12.1系统功能分析 ...............................................22.2系统物理模块设计 ...........................................2三、 数据库设计 .................................................23.1数据流需求分析 ............................................23.2概念模型设计 ...............................................53.3逻辑结构设计 ...............................................6四、数据库程序设计 ...............................................4.1用户登录模块 ...............................................674.2 主窗体模块 ...............................................4.3员工信息模块 ...............................................894.4工资信息模块 ...............................................9附录 .............................................................一、背景S家具企业始建于1954年,是一家有着40多年历史的老厂。
SQL数据库员工工资管理系统设计
SQL数据库员工工资管理系统设计设计一个SQL数据库员工工资管理系统,需要考虑以下几个方面:1.数据库设计:- 创建一个名为`employee`的表,包含以下字段:- `id`:员工ID,主键,自增长;- `name`:员工姓名;- `gender`:员工性别;- `position`:员工职位;- `salary`:员工工资;2.功能需求:- 添加员工:向`employee`表中插入一条新的员工记录;- 删除员工:从`employee`表中删除指定ID的员工记录;- 修改员工信息:更新`employee`表中指定ID的员工信息;- 查询员工工资:从`employee`表中查询指定ID的员工工资;- 查询员工列表:从`employee`表中查询所有员工的信息;- 查询工资最高者:从`employee`表中查询工资最高的员工;- 查询工资最低者:从`employee`表中查询工资最低的员工;3.数据库实现:- 在MySQL数据库中创建一个名为`salary_management`的数据库;- 在该数据库中创建一个名为`employee`的表,包含上述字段;-使用SQL语句来实现各个功能需求;- 删除员工:`DELETE FROM employee WHERE id = 1;`- 修改员工信息:`UPDATE employee SET position = '总监' WHERE id = 1;`- 查询员工工资:`SELECT salary FROM employee WHERE id = 1;` - 查询员工列表:`SELECT * FROM employee;`- 查询工资最高者:`SELECT * FROM employee WHERE salary = (SELECT MAX(salary) FROM employee);`- 查询工资最低者:`SELECT * FROM employee WHERE salary = (SELECT MIN(salary) FROM employee);`4.系统界面:- 可以使用Python的GUI库(如Tkinter)来设计一个用户友好的界面,实现上述功能;-当用户点击“添加员工”按钮时,界面会将用户输入的员工信息提交到数据库中;-当用户点击“查询工资最高者”按钮时,界面会从数据库中查询工资最高的员工,并显示在界面上。
工资管理系统设计
工资管理系统设计一、系统需求分析1.功能需求(1)员工信息管理:包括员工基本信息、薪资标准、薪资档案等;(2)考勤管理:记录员工的出勤情况,包括迟到、早退、缺勤等情况;(3)计算工资:根据考勤记录和薪资标准,自动计算每个员工的工资;(4)工资发放:生成工资条,记录发放日期和金额;(5)统计报表:生成工资统计报表,包括总工资、平均工资、最高工资、最低工资等。
2.性能需求(1)数据安全性:保护员工的个人隐私和工资信息,确保系统安全可靠;(2)操作便捷性:界面友好,操作简单方便,提供快速查询和查看功能;(3)计算准确性:计算工资的准确性是系统的关键,要确保计算结果精确无误;(4)数据存储和查询速度:要求数据库的存储和查询速度较快,以提高系统的响应速度。
二、系统设计1.数据库设计(1)员工信息表:包括员工ID、姓名、性别、部门、岗位、入职日期等;(2)考勤记录表:包括员工ID、打卡日期、上班时间、下班时间等;(3)工资标准表:包括工资标准ID、基本工资、奖金、补贴等;(4)工资发放表:包括员工ID、工资发放日期、金额等。
2.系统架构设计(1)前端设计:采用用户界面友好的Web页面,并提供登录、员工信息管理、考勤管理、工资计算及发放、统计报表等功能的页面;(2)后端设计:使用Java语言开发后台逻辑,实现与前端交互、数据的存储、计算和查询等功能;(3)数据库设计:使用关系型数据库如MySQL进行数据存储,设计合理的表结构和索引,保证数据的存储和查询速度;(4)系统安全设计:采用用户登录、权限管理和数据加密等手段,确保系统的安全性。
三、系统实施1.数据采集(1)员工信息采集:通过员工管理模块,录入员工的基本信息和薪资标准;(2)考勤记录采集:通过考勤管理模块,记录员工的打卡情况,包括上班时间、下班时间等。
2.工资计算与发放(1)根据考勤记录和薪资标准,自动计算每个员工的工资;(2)生成工资发放表,记录工资发放的日期和金额。
员工工资管理系统数据库设计报告
员工工资管理系统数据库设计报告1. 引言员工工资管理系统是企业管理中至关重要的一部分,对于员工的工资管理以及相关数据记录十分重要。
本报告旨在介绍员工工资管理系统的数据库设计,包括系统的实体关系模型、数据表设计以及数据表之间的关联。
2. 实体关系模型数据库设计的首要任务是构建实体关系模型(ER 模型),通过识别系统中的实体、属性和关系,从而建立系统的模型。
员工工资管理系统中包含以下实体:•员工(Employee):包括员工编号、姓名、性别、部门号等属性;•部门(Department):部门编号、部门名称、负责人等属性;•工资(Salary):工资编号、员工编号、基本工资、奖金、扣款等属性。
3. 数据表设计基于实体关系模型,我们可以设计出以下数据表:3.1 员工表(Employee)字段名数据类型备注员工编号INT 主键姓名VARCHAR(50)性别VARCHAR(10)部门号INT 外键参考部门表3.2 部门表(Department)字段名数据类型备注部门编号INT 主键部门名称VARCHAR(50)负责人VARCHAR(50)3.3 工资表(Salary)字段名数据类型备注工资编号INT 主键员工编号INT 外键参考员工表基本工资FLOAT奖金FLOAT扣款FLOAT4. 数据表之间的关联员工表和部门表之间存在一对多的关系,一个部门可以有多名员工,而一个员工只能归属于一个部门。
因此,员工表与部门表之间使用部门号进行关联。
工资表与员工表之间为一对一关系,一个员工只有一个工资信息,因此工资表与员工表之间使用员工编号进行关联。
5. 结论通过以上数据库设计,我们建立了一个简单而有效的员工工资管理系统数据库模型,包括员工表、部门表和工资表,确保了数据的一致性和关联性。
这个设计可以作为员工工资管理系统的基础,支持系统的数据存储和管理,为企业提供准确和可靠的工资管理服务。
以上是员工工资管理系统数据库设计报告的内容。
数据库课程设计——企业员工工资管理系统
数据库课程设计——企业员工工资管理系统一、引言在现代企业管理中,员工工资的管理是一个极为重要的环节。
为了提高工资管理的效率和准确性,需要设计和实现一套高效的企业员工工资管理系统。
本文将介绍如何在数据库课程设计中构建一个功能完善的企业员工工资管理系统。
二、系统需求分析企业员工工资管理系统需要满足以下基本需求:1. 员工信息管理:包括员工基本信息(姓名、性别、年龄等)、部门信息、职位信息等。
2. 工资计算:根据员工的基本工资、绩效考核等因素计算工资。
3. 工资发放:自动生成工资发放单,记录工资发放的时间和方式。
4. 工资查询:员工和管理人员能够查询工资详细信息,包括工资单、工资发放记录等。
5. 统计报表:生成各种工资统计报表,如部门工资总额、员工工资排名等。
三、系统设计与实现1. 数据库设计为了满足系统需求,需要设计一组适当的数据库表来存储相关数据。
以下是数据库表的设计方案:- 员工表(Employee):存储员工的基本信息(员工编号、姓名、性别、年龄等)。
- 部门表(Department):存储部门的信息(部门编号、部门名称等)。
- 职位表(Position):存储职位信息(职位编号、职位名称等)。
- 工资表(Salary):存储员工的工资信息(员工编号、基本工资、绩效等)。
- 工资发放表(SalaryPayment):记录工资的发放信息(员工编号、发放时间、发放方式等)。
2. 系统实现利用SQL语言和数据库管理系统,可以实现员工工资管理系统的各项功能需求。
以下是关键功能的实现示例:- 员工信息管理:通过SQL语句实现员工信息的增加、删除、修改和查询操作。
- 工资计算:编写SQL函数或存储过程来计算员工的工资,考虑到绩效考核等因素。
- 工资发放:编写SQL语句插入工资发放记录,记录发放时间和方式等信息。
- 工资查询:编写SQL语句实现员工和管理人员的工资查询功能,根据需要生成工资单。
- 统计报表:通过SQL语句生成工资统计报表,利用聚合函数和分组操作实现部门工资总额、员工工资排名等统计指标的计算。
数据库课程设计--工资管理系统
数据库课程设计设计题目:工资管理系统班级:学号:姓名:任务分配表目录一绪论 (3)二需求分析 (3)三概要设计 (4)四物理设计 (5)五详细设计 (6)六调试分析 (9)七小结 (16)八附件 (16)一、绪论随着计算机技术的飞速发展和经济体制改革的不断深入,传统企业管理方法、手段以及工作效率已不能适应新的发展需要,无法很好地完成员工工资管理工作。
提高公司企业管理水平的主要途径是更新管理者的思想,增强对管理活动的科学认识。
基于C#与SQL server数据库技术建立一个通用工资管理系统,该系统为提供了查询、增加记录、删除等功能,功能比较的齐全,并对工资进行了统计如津贴管理、报表统计等。
基本上能满足管理员和公司的要求。
此次数据库课程设计的主要设计如下:原理分析、程序设计过程、程序实现和程序调试以及数据库的设计。
需求分析、概要结构设计、逻辑结构设计、物理结构设计和数据库的实施和维护。
主要包括两大大功能模块:1.管理员管理界面设计。
2.员工管理界面设计。
二、需求分析功能需求分析:该通用工资管理系统具备下列功能:管理员通过输入用户名和密码进下该系统后,可以进行一些基本查询(员工信息查询、工资奖金信息查询)、工资管理(计算总工资、奖金管理);通过输入密码,可以进行查询员工的数据(工资,奖金,税收等)。
具体功能的详细描述如下1、在首页进行选择,员工与管理员通道2、点击[管理员登陆]3、用户名和密码即可进入 [工资管理]功能窗体,在此可以选择功能,添加,查询,人员列表4、点击[添加]功能窗体,添加员工工资信息。
5、点击[查询]功能窗体,输入员工号即可查询员工信息。
6、点击[人员列表]功能窗体,可查看所有员工的列表,这界面内可以进行删除操作。
7、点击[员工登陆]8、用户名和密码即可进入 [员工工资查询]功能窗体,在此可以选择查询基本信息,查询工资信息。
9、在[查询基本信息],员工可自己查看自己的信息。
10、在[查询工作信息],员工可自己查看自己的工作信息。
员工工资管理系统数据库设计
员工工资管理系统数据库设计一、需求分析为了更好的管理公司的员工工资,需要设计一套员工工资管理系统数据库,并且要具备以下功能:1. 员工工资核算:系统需要对员工的工资进行核算,并且能够根据不同的工资核算规则自动计算出员工的工资,并可以进行手动调整。
2. 工资发放:该系统需要支持工资的自动发放,如每月固定发放日期自动发放员工工资等。
3. 工资查询:该系统需要支持员工查询自己工资、管理员查询所有员工的工资等。
4. 工资统计:该系统需要支持对员工工资进行统计,如统计某个月份公司工资总和,平均工资,最高与最低工资,员工分布情况等。
5. 员工信息管理:该系统需要支持员工信息管理,如员工基本信息、部门信息、职位信息等。
6. 系统设置:该系统需要支持系统设置,可以对员工工资核算规则等设置进行修改。
二、数据库设计1. 数据库结构设计该数据库分为员工信息表、工资信息表、部门信息表、职位信息表、系统设置表等。
(1)员工信息表员工信息表包含员工基本信息、工资核算标准、所在部门、职位等信息。
CREATE TABLE employee( id INT(11) PRIMARY KEYAUTO_INCREMENT, name VARCHAR(50) NOT NULL, sex VARCHAR(5), age INT(3), department VARCHAR(50), position VARCHAR(50), base_salary FLOAT(7,2) NOT NULL, treatment FLOAT(7,2) NOT NULL, remarks VARCHAR(100));(2)工资信息表工资信息表包含员工的工资核算结果、所属月份等信息。
CREATE TABLE salary( id INT(11) PRIMARY KEYAUTO_INCREMENT, employee_id INT(11), salary_month VARCHAR(10) NOT NULL, salary FLOAT(7,2) NOT NULL,bonus FLOAT(7,2) NOT NULL, deduction FLOAT(7,2),create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, FOREIGN KEY (employee_id) REFERENCES employee(id));(3)部门信息表部门信息表包含部门名称、部门编号、所属公司等信息。
工资管理系统数据库课程设计
工资管理系统数据库课程设计工资管理系统数据库课程设计一、背景介绍现代企业的工资管理已经越来越复杂,需要一个高效、准确的工资管理系统来进行支持。
工资管理系统需要能够自动计算员工工资,但更重要的是需要保护员工信息的安全性。
因此,该系统需要具备高可靠性和高安全性。
二、系统设计要求1. 系统框架设计系统框架应该采用分层架构模式,包括以下几个层次:①用户界面层:实现用户与系统的交互操作。
②业务逻辑层:实现系统的核心业务逻辑。
③数据访问层:实现系统的数据访问和管理。
④数据库层:用于存储系统所需的数据。
2. 数据库设计数据表结构设计如下:①员工表:用于存储员工基本信息,包括员工号、姓名、性别、出生日期、联系电话等字段。
②工资表:用于存储员工工资信息,包括员工号、月份、基本工资、津贴、扣款等字段。
③部门表:用于存储部门信息,包括部门号、部门名称、部门经理等字段。
④职位表:用于存储职位信息,包括职位编号、职位名称、职位描述等字段。
⑤权限表:用于存储用户权限信息,包括用户名、密码、用户类型等字段。
3. 系统功能设计根据需求分析,系统应该包含以下功能:①员工基本信息维护功能:用于添加、修改、删除员工基本信息。
②员工工资信息维护功能:用于添加、修改、删除员工工资信息。
③员工考勤记录查询功能:用于查询员工的考勤记录。
④部门信息维护功能:用于添加、修改、删除部门信息。
⑤职位信息维护功能:用于添加、修改、删除职位信息。
⑥权限管理功能:用于管理用户的权限信息。
三、技术方案1. 数据库管理系统本系统采用MySQL数据库管理系统,因为MySQL是一个成熟的开源数据库系统,能够提供高效、可靠的数据存储和管理服务。
2. 开发工具本系统采用Java语言进行开发,使用Eclipse作为开发工具,采用Java Web开发技术,采用MVC设计模式。
3. 数据库访问框架本系统采用ORM框架Hibernate来进行数据库的访问操作,通过Hibernate能够简化数据库访问操作,提高系统开发效率。
javaMySql数据库课程设计(员工工资管理系统)
JavaMySQL数据库课程设计(员工工资管理系统)简介本文档是关于使用Java和MySQL数据库设计的员工工资管理系统的课程设计报告。
该系统旨在提供一个方便快捷的员工工资管理平台,帮助雇主轻松管理员工的工资信息。
功能概述•管理员功能1.登录/注销:管理员可以使用用户名和密码登录系统,并在不需要时注销账户。
2.添加员工:管理员可以添加新员工信息,包括姓名、性别、职位、工资等。
3.修改员工信息:管理员可以修改已有员工的个人信息,并更新工资等相关信息。
4.删除员工:管理员可以删除已有员工账号,同时删除与之相关的所有工资信息。
5.查询员工:管理员可以根据不同的条件查询员工信息,比如按部门、职位等。
6.导出工资表:管理员可以导出员工工资表,包括每个员工的姓名、工资、加班时长等信息。
•员工功能1.登录/注销:员工可以使用用户名和密码登录系统,并在不需要时注销账户。
2.查看个人信息:员工可以查看自己的个人信息,包括姓名、性别、职位、工资等。
3.修改个人信息:员工可以修改自己的个人信息,如联系方式、住址等。
4.查询工资信息:员工可以查询自己的工资信息,包括基本工资、奖金、扣款等。
5.查询加班记录:员工可以查询自己的加班记录,包括加班日期、加班时长等。
数据库设计本系统使用MySQL数据库管理员工工资信息,下面是数据库中的表格设计:表:员工信息表(employees)•字段:员工ID、姓名、性别、职位、工资•主键:员工ID•外键:无表:工资信息表(salaries)•字段:员工ID、基本工资、奖金、扣款、发放日期•主键:无(使用员工ID作为外键)•外键:员工ID(关联employees表)表:加班记录表(overtime_records)•字段:员工ID、加班日期、加班时长•主键:无(使用员工ID作为外键,与employees 表关联)•外键:员工ID(关联employees表)技术实现本系统采用Java作为开发语言,并使用MySQL作为后端数据库。
基于python的工资绩效管理系统的设计与实现
基于python的工资绩效管理系统的设计与实现设计和实现一个基于Python 的工资绩效管理系统涉及多个方面,包括数据库设计、用户界面设计、业务逻辑实现等。
以下是一个简单的指南,帮助你开始这个项目。
1. 数据库设计首先,你需要设计数据库以存储员工信息、工资信息和绩效数据。
使用SQLite、MySQL 或PostgreSQL 等数据库管理系统。
```sql--员工信息表CREATE TABLE employees (id INT PRIMARY KEY,name VARCHAR(100),position VARCHAR(100),department VARCHAR(100));--工资信息表CREATE TABLE salaries (id INT PRIMARY KEY,employee_id INT,salary_amount DECIMAL(10, 2),month DATE,FOREIGN KEY (employee_id) REFERENCES employees(id));--绩效信息表CREATE TABLE performance (id INT PRIMARY KEY,employee_id INT,performance_score INT,month DATE,FOREIGN KEY (employee_id) REFERENCES employees(id));```2. Python 代码#2.1 数据库连接使用Python 的数据库连接库(例如`sqlite3`、`mysql-connector` 或`psycopg2`)连接到你```pythonimport sqlite3# 连接到SQLite 数据库conn = sqlite3.connect('your_database.db')cursor = conn.cursor()```#2.2 员工管理实现员工信息的增加、删除和查询功能。
工资管理系统的数据库课程设计
课程设计报告书年 月1 设计时间2 设计目的掌握数据库的设计3设计任务设计一个工资管理系统4 设计内容〔1〕目标:1)实现月工资计算;2)实现与工资管理有关的档案管理。
3)提高工资管理工作效率,降低出错率。
〔2〕功能要求:档案管理1)保存有关工资计算以及工资管理所必须的数据2)能对数据进行查询、统计工资计算1)正确计算出个人月工资、部门月工资以及全厂月工资。
2)能对病假扣款系数进行修正。
3)能统计工资计算表、个人工资单、部门工资单、工资汇总表四种表格。
需求分析工资管理信息系统对企业加强工资管理有着极其重要的作用,就一般的大型企业来说,它的设计内容非常复杂而且繁多,比方拥有工资计算功能,工资统计功能,报表输出功能,而且设计的模块也很多,比方工资管理模块,工资统计模块,报表设计模块,打印输出模块,模糊查询模块等等。
由于设计时间本设计事一个简单模型,该公司目前对工资管理的要求并不高。
因此,针对该公司而言,我们经过了反复地论证,最终确定了工资管理系统的设计方案。
该工资管理系统的主要功能如下图:图4-1概念结构设计图4-2职工技术职称性别 出生日期参加工作日期所属部门人员类别工种类别 技术等级职工号文化程度 现住址籍贯民族工资管理系统职工基本信息 工资结构设置 工资汇总资料输入职工增删职工查询基础工资岗位工资工龄工资岗位工资工龄工资图4-3图4-4工资表岗位津贴住房补贴职务津贴物价补贴房租缺勤扣除工资加班费出勤表职工出勤日数工伤日数 产假日数旷工日数病假日数事假日数 加班日数夜班日数 病假系数图4-5 总ER 图逻辑结构设计职工表〔职工号 技术等级 性别 出生日期 参加工作日期 所属部门 人员类别 工种职别技术职称 文化程度 民族 籍贯 现住址 〕工资表〔技术等级 职工的基本工资 岗位津贴 物价补贴 职位津贴 住房补贴 房租〕出勤表〔职工号 职工出勤 工伤日数 产假日期 病假日期 旷工日期 事假日期 加班日期 夜班日期 病假日期〕物理结构设计职工表4-1字段名称 类型 是否为空 主关键字 取值范围 备注 职工号 char 否 Y 主键 char 否 N 性别 char 否 N 出生日期datetime否N职工出勤表工资表职工号 性别 民族职工号 技术等级物价补贴 岗位津贴物价补贴住房补贴 技术等级加班费 旷工日数加班日数职工代号工伤日数产假日数事假日数病假日数影响影响参加工作datetime 否 N日期所属部门 char 否 N人员类别 char 否 N工种职别 char 否 N技术等级 char 否 N技术职称 char 否 N文化程度 char 否 N民族 char 否 N籍贯 char 否 N现住址 char 否 N工资表4-2字段名称 类型 是否为空 主键字 取值范围 备注 技术等级 char 否 Y 主键 岗位津贴 int 否 N物价补贴 int 否 N职务津贴 int 否 N住房补贴 int 否 N房租 int 否 Nint 否 N缺勤扣除工资加班费 int 否 N出勤表4-3字段名称 类型 是否为空 主键字 取值范围 备注 职工号 char 否 Y 主键 int 否 N职工的出勤日数工伤日数 int 否 N产假日数 int 否 N病假日数 int 否 N旷工日数 int 否 N事假日数 int 否 N加班日数 int 否 N夜班日数 int 否 N病假系数 int 否 N数据库实现职工号 char(10) primary key,create table ZG(char(10) not null,性别 char(10) not null,出生日期 datetime not null,参加工作日期 datetime not null ,所属部门 char (20) not null,人员类别 char(10) not null,工种职别 char (10) not null,技术等级 char (10) not null,技术职称 char (10) not null,文化程度 char (10) not null,民族 char (10) not null,籍贯 char (10) not null,现住址 char (10) ) not null;技术等级 char(10) primary key not null, create table GZ(职工的基本工资 int not null ,岗位津贴 int not null ,物价补贴 int not null ,职务津贴 int not null,住房补贴 int not null,房租 int not null );职工号 char(10) primary key,create table CQ(职工的出勤日数 int ,公伤日数 int not null,产假日数 int not null ,病假日数 int not null,旷工日数 int not null,事假日数 int not null,加班日数 int not null ,夜班日数 int not null ,病假系数 int not null);数据载入职工表的数据图4-6工资表的数据图4-7出勤表的数据图4-8运行与测试设计系统查询功能及要求,写出主要的查询SQL语句,并给出运行结果。
工资系统数据库课程设计
工资系统数据库课程设计一、课程目标知识目标:1. 理解数据库在工资管理系统中的应用和重要性;2. 掌握工资管理系统的基本功能模块及其数据表结构设计;3. 学会运用SQL语句进行工资数据的查询、插入、更新和删除操作;4. 了解数据库的安全性和一致性原则在工资系统中的应用。
技能目标:1. 能够独立设计并实现一个简单的工资管理系统数据库;2. 能够运用所学知识,对工资数据进行有效管理和维护;3. 能够通过数据库查询和分析,解决工资管理中的实际问题;4. 学会使用数据库管理工具(如:MySQL、Oracle等)进行数据操作。
情感态度价值观目标:1. 培养学生对数据库技术在工资管理系统中的应用产生兴趣,提高学习积极性;2. 培养学生严谨、细心的数据处理能力和团队合作精神;3. 增强学生对信息技术的认识,使其意识到信息技术在企业管理中的重要作用;4. 培养学生尊重劳动、诚实守信的品质,提高社会责任感。
课程性质:本课程为实践性较强的课程,以培养学生的实际操作能力和解决问题的能力为主。
学生特点:学生具备一定的数据库基础知识和计算机操作技能,但可能对工资管理系统的实际应用了解不多。
教学要求:结合学生特点和课程性质,注重理论与实践相结合,以案例教学为主,培养学生的实际操作能力和分析解决问题的能力。
在教学过程中,关注学生的学习进度和情感态度,确保课程目标的实现。
通过课程学习,使学生能够将所学知识应用于实际工作中,提高其职业素养。
二、教学内容1. 工资管理系统概述- 了解工资管理系统的基本概念和功能模块;- 分析工资管理系统的业务流程。
2. 数据库设计基础- 学习数据库设计的基本原则和步骤;- 掌握实体关系模型和关系数据库设计方法。
3. 工资管理系统数据库设计- 设计工资管理系统所需的数据表结构;- 学习如何建立实体和关系,并进行属性定义。
4. SQL语句操作- 掌握SQL基本操作(查询、插入、更新、删除);- 学习运用SQL语句对工资数据进行管理。
javaMySql数据库课程设计(员工工资管理系统)
Java MySql数据库课程设计 - 员工工资管理系统1. 引言在现代企业中,员工工资管理是一项非常重要的任务。
合理管理员工工资不仅可以激励员工的积极性,还可以提高企业的运营效率。
为了更好地管理员工工资,我们决定设计一个员工工资管理系统,使用Java编程语言与MySql数据库进行开发。
2. 功能需求该员工工资管理系统将包含以下功能模块: - 员工信息管理:包括添加员工、删除员工、查看员工信息、修改员工信息等功能。
- 工资管理:包括录入员工工资、计算员工工资、查询员工工资等功能。
- 统计分析:包括统计部门工资总和、统计员工工资平均值等功能。
3. 技术选型为了实现上述功能需求,我们选择使用Java编程语言与MySql数据库进行开发。
以下是我们选择这些技术的原因: - Java是一种面向对象的编程语言,具有良好的可读性和可维护性,适合开发大型项目。
- MySql是一种关系型数据库管理系统,具有高性能和可扩展性,适合处理大量的数据。
4. 数据库设计4.1 数据表设计我们将设计两个数据表来存储员工信息和工资信息。
4.1.1 员工信息表字段名称数据类型说明id int员工IDname varchar员工姓名age int员工年龄gender varchar员工性别department varchar员工部门4.1.2 工资信息表字段名称数据类型说明id int工资IDemployee_id int员工IDmonth varchar月份salary decimal工资金额4.2 数据库查询语句以下是一些常用的数据库查询语句,用于实现系统功能模块:4.2.1 添加员工INSERT INTO employee (id, name, age, gender, d epartment)VALUES (1001, '张三', 25, '男', '技术部');4.2.2 删除员工DELETE FROM employee WHERE id=1001;4.2.3 查看员工信息SELECT*FROM employee;4.2.4 修改员工信息UPDATE employee SET age =26WHERE id=1001;4.2.5 录入员工工资INSERT INTO salary (id, employee_id, month, sa lary)VALUES (1, 1001, '2021-01', 5000);4.2.6 计算员工工资SELECT SUM(salary) FROM salary WHERE employee_ id =1001;4.2.7 查询员工工资SELECT*FROM salary;4.2.8 统计部门工资总和SELECT department, SUM(salary) FROM employee JOIN salary ON employee.id= salary.employee_id GROUP BY department;4.2.9 统计员工工资平均值SELECT employee_id, AVG(salary) FROM salary GROUP BY employee_id;5. 系统架构为了提高系统的扩展性和灵活性,我们将采用三层架构来设计该员工工资管理系统。
工资管理系统数据库课程设计报告
工资管理系统数据库课程设计报告
设计工资管理系统的数据库需要考虑以下几个方面:
1.数据表设计:需要设计一个数据表来存储员工信息,包括员工ID、员工姓名、员工工资、员工职位等字段。
同时还需要设计一个数据表来存储薪资信息,包括薪资ID、员工ID、薪资水平、薪酬结构等字段。
两个数据表需要进行关联关系的设计,以实现员工信息与薪资信息的存储和查询。
2.关系设计:需要设计一个关系来将员工信息和薪资信息进行关联。
可以使用主外键关系来实现,其中员工信息表的主键是员工ID,薪资信息表的主键是薪资ID。
这样可以保证两个数据表的关联关系正确无误。
3.功能设计:需要考虑工资管理系统的各项功能,包括员工信息查询、薪资信息查询、员工信息修改、薪资信息修改等。
需要根据功能设计相应的操作界面和业务逻辑。
4.安全性设计:需要考虑工资管理系统的安全性,包括用户权限管理、数据备份和恢复、安全漏洞检测和修复等。
需要设计合适的安全措施,以保证数据和系统的安全。
5.性能设计:需要考虑工资管理系统的性能,包括查询速度、存储容量、数据更新速度等。
需要根据实际情况进行性能优化,以保证系统正常运行。
6.数据库备份和恢复:需要考虑数据库备份和恢复的能力,包括备份策略、备份文件大小、备份频率、恢复操作等。
需要设计合理的
备份和恢复方案,以保证数据的安全和完整性。
以上是设计工资管理系统数据库课程设计的几个方面,当然还有其他需要注意的问题,需要根据具体情况进行分析和设计。
工资系统数据库结构设计说明书
工资系统数据库结构设计说明书工资系统数据库结构设计说明书一、引言本文档旨在详细描述工资系统数据库的结构设计,包括数据库的表结构、字段定义、索引设计以及数据库关系模型等内容。
通过本文档的编写和阅读,开发人员可以清晰地了解和掌握工资系统数据库的设计原理和结构。
二、数据库概述1.数据库系统名称:工资系统数据库2.数据库系统版本.1.03.数据库系统设计目标:为公司内部管理系统提供工资信息的存储和查询功能4.数据库系统设计范围:包括员工信息、工资标准、工资发放记录等关键信息的存储和管理。
三、数据库结构设计1.员工信息表1.1 字段定义员工编号、姓名、性别、出生日期、入职日期、部门编号、职务编号、联系方式、联系号、籍贯、住址等。
1.2 索引设计a.主键索引:员工编号b.唯一索引:联系号c.普通索引:部门编号、职务编号2.工资标准表2.1 字段定义标准编号、职务编号、基本工资、岗位津贴、绩效工资、加班工资、奖金、社保费用等。
2.2 索引设计a.主键索引:标准编号b.普通索引:职务编号3.工资发放记录表3.1 字段定义记录编号、员工编号、发放日期、应发工资、实发工资等。
3.2 索引设计a.主键索引:记录编号b.普通索引:员工编号、发放日期四、数据库关系模型设计1.员工信息表与工资标准表的关系一对多关系,一个员工可以对应一个工资标准,一个工资标准可以对应多个员工。
2.员工信息表与工资发放记录表的关系一对多关系,一个员工可以有多条工资发放记录,一条工资发放记录只能对应一个员工。
五、附件本文档涉及的附件包括工资系统数据库的逻辑模型图、物理模型图等,请参阅附件文件。
六、法律名词及注释1.数据库:指具有组织、存储和管理数据的系统。
2.数据库系统:指由数据库、数据库管理系统(DBMS)和应用程序组成的数据管理系统。
人事工资管理系统数据库设计
人事工资管理系统数据库设计人事工资管理系统是一个重要的企业管理系统,它主要用来管理企业的员工信息和工资发放情况。
在设计人事工资管理系统的数据库时,需要考虑到数据的完整性、安全性和易用性。
下面就是一个人事工资管理系统数据库的设计。
一、员工信息表设计员工信息表是人事工资管理系统的核心表之一,它主要用来存储企业员工的基本信息。
员工信息表的字段设计如下:1. 员工编号(EmployeeID):主键,用来唯一标识一个员工。
2. 员工姓名(EmployeeName):员工的姓名。
3. 性别(Gender):员工的性别。
4. 出生日期(BirthDate):员工的出生日期。
5. 职位(Position):员工的职位。
6. 入职日期(HireDate):员工的入职日期。
7. 部门编号(DepartmentID):表示员工所属的部门,是一个外键,与部门信息表的部门编号字段相对应。
二、部门信息表设计部门信息表用来存储企业的各个部门的相关信息。
部门信息表的字段设计如下:1. 部门编号(DepartmentID):主键,用来唯一标识一个部门。
2. 部门名称(DepartmentName):部门的名称。
3. 上级部门编号(ParentDepartmentID):表示上级部门的编号,是一个外键,与部门信息表的部门编号字段相对应。
三、工资信息表设计工资信息表用来存储员工的工资信息。
工资信息表的字段设计如下:1. 工资编号(SalaryID):主键,用来唯一标识一个工资信息。
2. 员工编号(EmployeeID):表示工资信息所属的员工,是一个外键,与员工信息表的员工编号字段相对应。
3. 发放日期(PaymentDate):工资的发放日期。
4. 基本工资(BaseSalary):员工的基本工资。
5. 奖金(Bonus):员工的奖金。
6. 扣款(Deduction):员工的扣款。
7. 实发工资(ActualSalary):员工的实际发放工资。
教师工资管理系统数据库设计
教师工资管理系统数据库设计我是AI语言模型,下面是我自动生成的“教师工资管理系统数据库设计”的文档。
仅供参考,欢迎指正。
一、需求分析教师工资管理系统是一个涉及到多个模块的系统,包括教师信息管理、薪资管理、考勤管理、福利管理等。
因此,在数据库设计阶段需要从需求出发,确定系统的数据实体、属性和关系,而数据实体又可以分解为教师实体、薪资实体、考勤实体等。
下面就对各数据实体的需求进行分析。
1、教师实体教师实体是教师工资管理系统的核心实体,包含了教师的基本信息、教授课程信息、工资信息等。
教师实体的属性包括教师ID、教师姓名、性别、出生日期、身份证号、毕业院校、专业、职称、联系方式、所授课程、入职时间、工龄等。
2、薪资实体薪资实体是记录教师工资信息的实体,包括教师基本工资、绩效奖金、津贴、扣罚等。
薪资实体的属性包括教师ID、基本工资、绩效奖金、津贴、扣罚、实际发放工资、发放日期等。
3、考勤实体考勤实体是记录教师考勤信息的实体,包括出勤天数、缺勤天数、迟到早退次数等。
考勤实体的属性包括教师ID、出勤日期、出勤状态、请假天数、缺勤天数、迟到早退次数等。
4、福利实体福利实体是记录教师福利信息的实体,包括社保信息、住房补贴、交通补贴、假期等。
福利实体的属性包括教师ID、社保信息、住房补贴、交通补贴、带薪假期、病假等。
二、数据库设计根据需求分析,可以设计一个包含教师实体、薪资实体、考勤实体和福利实体的关系数据库。
其中,教师实体作为主表,薪资实体、考勤实体和福利实体作为从表。
1、教师表设计教师表包含教师的基本信息,包括教师ID、教师姓名、性别、出生日期、身份证号、毕业院校、专业、职称、联系方式、所授课程、入职时间、工龄等。
其中,教师ID为主键。
2、薪资表设计薪资表包含教师的工资信息,包括教师ID、基本工资、绩效奖金、津贴、扣罚、实际发放工资、发放日期等。
其中,教师ID为主键,与教师表通过一对一关系连接。
薪资表也可以与考勤表、福利表相连接。
员工工资管理系统数据库设计E-R模型
员工工资管理系统数据库设计E-R模型背景在现代企业管理中,员工工资管理系统是一个至关重要的组成部分,它负责记录员工的薪资、报销、考勤等信息。
为了提高管理效率,降低人工成本,设计一个合理的数据库结构至关重要。
本文将介绍员工工资管理系统的E-R模型设计。
实体1.员工( Employee ):存储员工的基本信息,如姓名、职位、员工号等。
2.部门( Department ):记录公司内部各个部门的信息,包括部门名称、部门编号等。
3.工资( Salary ):存储员工的薪资信息,包括基本工资、奖金、扣款等。
4.报销( Reimbursement ):记录员工的报销情况,包括金额、报销时间等。
5.考勤( Attendance ):记录员工的考勤信息,包括请假、加班情况等。
关系1.员工与部门:一个员工属于一个部门,一个部门可以有多个员工,使用“隶属于”关系连接。
2.员工与工资:一个员工对应一个工资记录,一个工资记录只能对应一个员工,使用“拥有”关系连接。
3.员工与报销:一个员工可以有多条报销记录,一条报销记录只能对应一个员工,使用“属于”关系连接。
4.员工与考勤:一个员工可以有多条考勤记录,一条考勤记录只能对应一个员工,使用“参与”关系连接。
E-R模型erDiagramEmployee ||--o| Department : 隶属于Employee ||--o| Salary : 拥有Employee ||--o| Reimbursement : 属于Employee ||--o| Attendance : 参与以上是员工工资管理系统的E-R模型设计,通过这样的数据库结构,可以有效地管理员工的信息,实现工资的发放、报销的记录以及考勤的管理,提高了管理效率和准确性。
员工工资管理系统数据库设计er图
员工工资管理系统数据库设计er图系统简介员工工资管理系统是一个用于管理公司内部员工工资信息的系统,通过该系统可以方便地记录员工的基本信息、工资信息以及薪酬发放情况。
为了更好地设计和管理系统,需要建立相应的数据库以存储和管理员工的相关信息。
实体关系模型ER图下面是员工工资管理系统数据库设计的ER图:erDiagramEmployee {string EmployeeIDstring Namestring Departmentstring Positiondate HireDatefloat Salary}Salary_Record {string RecordIDstring EmployeeIDfloat BasicSalaryfloat Bonusdate SalaryDate}Department {string Departmentstring Managerint NumberOfEmployees}Employee ||--o| Salary_RecordEmployee ||--| DepartmentDepartment ||--o| Employee实体说明1.Employee(员工):记录员工的基本信息,包括员工ID、姓名、部门、职位、入职日期和基本工资。
2.Salary_Record(工资记录):记录员工的工资情况,包括工资记录ID、员工ID、基本工资、奖金和发放日期。
3.Department(部门):记录部门的信息,包括部门名称、部门经理和部门内的员工数量。
关系说明1.每个员工可以对应多条工资记录,表示员工的薪酬情况可以有多条记录。
2.每个员工属于一个部门,一个部门可以有多个员工,表示员工和部门之间是多对一的关系。
3.每个部门有一个部门经理,一个部门可以拥有多个员工,表示部门经理和部门员工之间是一对多的关系。
总结通过以上ER图的设计,我们可以清晰地了解员工工资管理系统中的实体及其之间的关系。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
工资管理系统课程:数据库姓名:孔洁教师:张福安目录1 系统概述 (1)2 系统数据流程图和数据字典 (3)2.1 用户需求调查 (3)2.2 系统数据流程图 (4)2.3 系统数据字典 (7)3 数据库结构设计 (13)3.1 概念结构设计 (12)3.2 逻辑结构设计 (12)3.3 数据库结构的详细设计 (14)4 物理设计 (15)5 用户的子模式(外模式)设计(没做) (19)6 总结 (19)1 系统概述本文按照数据库系统设计的基本步骤,采取了事先进行需求分析,然后进行数据库的概念设计和逻辑结构设计,最后进行数据库详细设计的方法,完成了一个工资管理系统数据库系统的设计。
最终,在Acess 2010完成的工资管理系统,可以实现添加和修改员工的个人详细信息、记录公司内部的人事调动情况、实现员工考勤记录查询和员工工资查询,整个系统重点放在工资管理上。
2 系统数据流程图和数据字典2.1 用户需求调查通过对现行工资管理系统的调查,明确了工资管理系统由员工信息查询,员工人事变更记录,员工考勤记录查询,员工工资查询组成。
系统功能的主要描述如下。
(1)员工信息查询对公司里所有员工进行统一编号;将每一位员工的信息保存在员工档案记录中。
对新聘用的员工,将其信息加入到员工档案记录中;对于解聘的员工,将其信息从员工档案记录中删除。
当员工的信息发生变动时,修改员工档案记录中相应的属性。
(2)员工人事变更记录管理对公司里所有员工的职务记录进行统一编号;登记员工调动前后的具体职务,以及调动时间。
(3)考勤管理对员工上班刷卡的记录进行统一编号;登记员工上班时间、签到类型(准时、迟到)。
对员工下班刷卡的记录进行统一编号;登记员工上班时间、签到类型(准时、早退)。
(6)工资管理对公司里所有员工的工资记录进行统一编号,建立工资记录表。
2.2 系统数据流程图经过详细的调查,弄清了系统现行的业务流程。
在此基础上,构造出系统的逻辑模型,并通过数据流程图表示。
数据流程图:2.3 系统数据字典 人事管理系统数据流程图中,数据信息和处理过程还需要通过数据字典员工信息工资项来描述。
在本文的数据字典中,主要对数据流图中的数据流、数据存储和处理过程进行说明。
(1)主要的数据流定义数据流名称:员工情况定义: 员工情况=姓名+性别+部门编号+职位+学历+毕业学校+专业+家庭住址+电话+状态。
数据流量:根据公司的员工具体录用情况来确定。
说明:要对每一位被聘用的新员工进行唯一编号。
数据流名称:调动情况定义: 调动情况=员工号+调动前职务+调动后职务+调动日期。
数据流量:根据公司的具体情况来确定。
说明:员工号和调动日期可以唯一确定一个调动情况。
数据流名称:签到记录定义: 上班刷卡=员工号+班次时间+签到时间。
数据流量:根据公司的具体规模情况来确定。
说明:签到时间会汇入到出勤记录中。
数据流名称:签出记录定义: 下班刷卡=员工号+班次时间 +签出时间。
数据流量:根据公司的具体情况来确定。
说明:签出时间会汇入到出勤记录中。
数据流名称:工资查询定义: 工资查询=员工号+基本工资+岗位津贴+加班补贴+出差补贴+违纪扣除+发薪日期。
数据流量:根据公司的具体情况来确定。
说明:根据员工号和发薪日期可以唯一确定一个工资记录。
数据流名称:缺勤记录定义: 请假申请=员工号+缺勤原因+缺勤天数+缺勤开始时+缺勤结束时。
数据流量:根据公司的具体情况来确定。
说明:员工号和请假时间可以唯一确定一个缺勤记录。
数据流名称:管理员情况定义: 用户身份=员工编号+用户名+密码。
数据流量:根据公司的具体情况来确定。
说明:要对每一位管理员建立唯一的账号。
数据流名称:用户身份定义: 用户身份=[ 非法用户 | 内部管理员 | 服务管理员]数据流量:根据公司的具体情况来确定。
说明:不同的用户身份对应不同的操作权限,对应着不同的安全级别。
数据流名称:部门情况位置:上级→部门情况定义: 部门情况=部门号+部门名称+经理。
数据流量:根据公司的具体情况来确定。
说明:部门号是主码。
(2)主要的数据存储定义数据存储编号:员工记录数据结构:员工记录=姓名+性别+部门编号+职位+学历+毕业学校+专业+家庭住址+电话+状态。
数据量和存取频度:根据公司的具体规模情况来确定。
存取方式:联机处理;检索和更新;以随机检索为主。
说明:员工编号具有唯一性和非空性;性别只能是男或女;主码是员工编号。
数据存储编号:缺勤记录数据结构:缺勤记录=员工号+缺勤原因+缺勤天数+缺勤开始时+缺勤结束时。
数据量和存取频度:根据公司的具体规模情况来确定。
存取方式:联机处理;检索和更新;以更新操作为主。
说明:主码设为缺勤时间和员工号;员工号是外码,参照表是员工记录。
数据存储编号:工资记录数据结构:工资记录=员工号+基本工资+岗位津贴+加班补贴+出差补贴+违纪扣除+发薪日期。
数据量和存取频度:根据公司的具体规模情况来确定。
存取方式:联机处理;检索和更新;以更新操作为主。
说明:主码设为发薪日期和员工号;员工号是外码,参照表是员工记录。
数据存储编号:职务调动记录数据结构:职务调动记录=员工号+调动前职务+调动后职务+调动日期数据量和存取频度:根据公司的具体规模情况来确定。
存取方式:联机处理;检索和更新;以更新操作为主。
说明:主码设为调动日期和员工号;员工号是外码,参照表是员工记录。
数据存储编号:管理人员记录数据结构:管理人员记录=用户密码+职工号+密码+管理员账号。
数据量和存取频度:根据公司的具体规模情况来确定。
存取方式:联机处理;检索和更新;以更新操作为主。
说明:主码设为管理员账号。
数据存储编号:出勤记录数据结构:出勤记录=员工号+签到时间+签出时间+刷卡日期。
数据量和存取频度:根据公司的具体规模情况来确定。
存取方式:联机处理;检索和更新;以更新操作为主。
说明:主码设为员工号和刷卡日期;员工号是外码,参照表是员工记录。
数据存储编号:部门记录数据结构:部门记录=部门号+部门名称+经理。
数据量和存取频度:根据公司的具体规模情况来确定。
存取方式:联机处理;检索和更新;以检索操作为主。
说明:主码设为部门号。
(3)主要的处理过程处理过程编号:处理过程名:档案管理输入:用户身份,员工记录,员工情况输出:员工记录处理说明:根据员工的聘用、解聘建立或删除员工记录,以及在后续的过程中,以管理员身份对员工的记录进行修改。
处理过程编号:处理过程名:销假管理输入:销假申请,请假批复,用户身份,员工记录,销假记录输出:请假记录处理说明:根据员工的销假申请,把销假时间录入到相应的请假记录中。
处理过程编号:处理过程名:请假管理输入:请假申请,请假批复,用户身份,员工记录,请假记录输出:请假记录处理说明:根据员工的请假申请和批复情况,进行请假表的登记。
处理过程编号:处理过程名:工资管理输入:用户身份,工资记录输出:工资记录,工资查询处理说明:根据员工目前的工资情况,进行调薪的操作。
处理过程编号:处理过程名:调动管理输入:调动批复,用户身份,职务调动记录输出:职务调动记录,调动情况处理说明:根据调动批复的内容,更改员工的职务信息,并对调动情况进行记录。
处理过程编号:处理过程名:安全管理输入:管理员情况处理说明:建立管理人员记录表;通过用户名和口令,确认用户身份,保证系统安全性。
处理过程编号:处理过程名:上班管理输入:签到时间,用户身份,员工记录,出勤记录输出:出勤记录处理说明:根据输入的员工号信息,记录上班时间,并判断是否迟到。
处理过程编号:处理过程名:下班管理输入:签出时间,用户身份,员工记录,出勤记录输出:出勤记录处理说明:根据输入的员工号信息,记录下班时间,并判断是否早退。
处理过程编号:处理过程名:部门管理输入:部门情况,部门记录输出:部门记录处理说明:根据上级的调度,对现在公司的部门进行领导人的调换,或者是增加或删除某一部门。
3 数据库结构设计3.1 概念结构设计根据系统需求分析,可以得出工资管理系统数据库的概念模型(信息模型),用E-R图表示的工资管理系统的概念模型。
最后,对设计出的数据模型进行规范化处理,使数据模型满足第三范式。
3.2 逻辑结构设计将人事管理系统的E-R图转换为关系数据库的数据模型,其关系模式为:(1)员工档案(员工情况=姓名+性别+部门编号+职位+学历+毕业学校+专业+家庭住址+电话+状态 +部门号),其中员工编号为主码,部门号为外码;(2)管理员记录(管理员账号,员工编号,密码,级别),其中管理员账号为主码,员工编号为外码;(3)请假记录(请假编号+员工编号+缺勤开始时+缺勤天数+缺勤结束时)请假编号为主码,其中员工编号外码。
(4)职务调动记录(调动编号+员工编号+调动前职务+调动后职务+调动日期),调动编号为主码,其中员工编号;(6)出勤记录(出勤编号+员工号+签到时间+签出时间),出勤编号为主码,员工号为外码;(7)工资记录(员工号+基本工资+岗位津贴+加班补贴+出差补贴+违纪扣除+发薪日期),工资编号为主码,员工号为外码。
(8)部门记录(部门编号+名称+领导人号),部门编号为主码。
将工资管理系统定名为“工资管理系统”。
各实体的分E-R图,如图A,B,C 所示:A)员工实体图B)部门实体图C)管理人员实体图全局E-R图,如图E所示:E)各实体间的联系图3.3 数据库结构的详细设计经过检查,此数据库的详细逻辑设计满足第3范式的要求。
人事管理系统中各表的属性设计情况如下表1:表14 物理设计4.1数据库物理设计阶段的任务是根据具体计算机系统(DBMS和硬件等)的特点,为给定的数据库系统确定合理的存储结构和存取方法。
所谓的“合理”主要有两个含义:一个是要使设计出的物理数据库占用较少的存储空间,另一个对数据库的操作具有尽可能高的速度。
主要体现在后者。
(1)建立索引:①对表部门在属性列领导人号上建立非聚集索引,②对表员工在属性列出生日期上建立非聚集索引,在属性列学历上建立非聚集索引③对表出勤在属性列上班日期上建立非聚集索引④对表工资在属性列基本工资上建立非聚集索引⑤对表职务调动在属性列调动前职务上建立非聚集索引。
对表请假记录在属性列“请假天数”上建立非聚集索引,在属性列“审批人编号”上建立非聚集索引。
(2)存储结构确定数据库的存储结构主要指确定数据的存放位置和存储结构,包括确定关系、索引、日志、备份等的存储安排及存储结构,以及确定系统存储参数的配置。
将日志文件和数据库对象(表、索引等)分别放在不同的磁盘,可以改进系统的性能,提高系统的安全性。
所以,系统应将日志文件和数据文件存放在不同磁盘上。
4.2数据库的建立4.3实验数据的输入为了验证所设计的数据库的性能,在ACESS 2010上建立的“工资管理系统”数据库,输入了少量的实验数据。