【数据分析面试】54.员工信息(HR)数据库搭建

news2024/11/15 17:19:17

在这里插入图片描述

题目

由于发展需求,进一步提高公司人员统筹管理的能力,公司决定要重新升级人力数据管理系统。

现在,你的任务是为公司重新设计和搭建一个员工信息数据库

提示:考虑HR管理系统的功能,比如人员信息、入职时间、离职时间、薪资数据等等。
![[54.员工信息(HR)数据库搭建-20240527140133735.webp|507]]

数据库表设计

1. Employees(员工表)

存储员工的基本信息。

  • EmployeeID: INT, 主键
  • FirstName: VARCHAR(50)
  • LastName: VARCHAR(50)
  • Gender: CHAR(1) (M/F)
  • BirthDate: DATE
  • HireDate: DATE
  • PositionID: INT, 外键(引用Positions表)
  • DepartmentID: INT, 外键(引用Departments表)
  • ManagerID: INT, 外键(引用本表)
  • Email: VARCHAR(100)
  • Phone: VARCHAR(15)
  • Address: VARCHAR(200)
  • City: VARCHAR(50)
  • State: VARCHAR(50)
  • ZipCode: VARCHAR(10)
  • EmploymentStatus: VARCHAR(20)
  • EmergencyContactName: VARCHAR(100)
  • EmergencyContactPhone: VARCHAR(15)
  • EmergencyContactRelation: VARCHAR(50)
  • TerminationDate: DATE
  • TerminationReason: VARCHAR(255)
2. Departments(部门表)

存储公司的部门信息。

  • DepartmentID: INT, 主键
  • DepartmentName: VARCHAR(100)
  • Location: VARCHAR(100)
  • ManagerID: INT, 外键(引用Employees表)
  • CreatedDate: DATE
  • UpdatedDate: DATE
3. Positions(职位表)

存储职位信息。

  • PositionID: INT, 主键
  • PositionTitle: VARCHAR(100)
  • SalaryGrade: INT
  • DepartmentID: INT, 外键(引用Departments表)
  • JobDescription: TEXT
  • CreatedDate: DATE
  • UpdatedDate: DATE
4. Salaries(薪资表)

存储员工的薪资信息。

  • SalaryID: INT, 主键
  • EmployeeID: INT, 外键(引用Employees表)
  • SalaryAmount: DECIMAL(10, 2)
  • EffectiveDate: DATE
  • EndDate: DATE
5. Attendances(考勤表)

存储员工的考勤记录。

  • AttendanceID: INT, 主键
  • EmployeeID: INT, 外键(引用Employees表)
  • Date: DATE
  • CheckInTime: TIME
  • CheckOutTime: TIME
6. PerformanceReviews(绩效评估表)

存储员工的绩效评估记录。

  • ReviewID: INT, 主键
  • EmployeeID: INT, 外键(引用Employees表)
  • ReviewDate: DATE
  • ReviewerID: INT, 外键(引用Employees表)
  • Rating: INT
  • Comments: TEXT
  • Goals: TEXT

说明

  1. Employees表包含了员工的基本信息,并通过外键关联到DepartmentsPositions表。每个员工可能有一个上级经理,这通过ManagerID来实现自引用。
  2. Departments表记录了部门信息,每个部门可以有一个经理。
  3. Positions表记录了职位信息,包括薪资等级和所属部门。
  4. Salaries表存储了员工的薪资记录,允许追踪薪资的变化。
  5. Attendances表记录了员工每日的考勤情况。
  6. PerformanceReviews表记录了员工的绩效评估信息,包括评分和评论。

这个Schema设计可以覆盖大部分HR系统的基本需求,但在实际应用中可能还需要根据具体需求进行扩展和修改。

代码示例(部分)

以下是SQL代码,可以创建相应的表并处理外键引用,以确保表能够正确创建。注意表的创建顺序以及外键约束的处理。

-- 创建 Departments 表
CREATE TABLE Departments (
    DepartmentID INT PRIMARY KEY,
    DepartmentName VARCHAR(100),
    Location VARCHAR(100),
    ManagerID INT,
    CreatedDate DATE,
    UpdatedDate DATE
);

-- 创建 Positions 表
CREATE TABLE Positions (
    PositionID INT PRIMARY KEY,
    PositionTitle VARCHAR(100),
    SalaryGrade INT,
    DepartmentID INT,
    JobDescription TEXT,
    CreatedDate DATE,
    UpdatedDate DATE,
    FOREIGN KEY (DepartmentID) REFERENCES Departments(DepartmentID)
);

-- 创建 Employees 表
CREATE TABLE Employees (
    EmployeeID INT PRIMARY KEY,
    FirstName VARCHAR(50),
    LastName VARCHAR(50),
    Gender CHAR(1) CHECK (Gender IN ('M', 'F')),
    BirthDate DATE,
    HireDate DATE,
    PositionID INT,
    DepartmentID INT,
    ManagerID INT,
    Email VARCHAR(100),
    Phone VARCHAR(30),
    Address VARCHAR(200),
    City VARCHAR(50),
    State VARCHAR(50),
    ZipCode VARCHAR(10),
    EmploymentStatus VARCHAR(20),
    EmergencyContactName VARCHAR(100),
    EmergencyContactPhone VARCHAR(30),
    EmergencyContactRelation VARCHAR(50),
    TerminationDate DATE,
    TerminationReason VARCHAR(255),
    FOREIGN KEY (PositionID) REFERENCES Positions(PositionID),
    FOREIGN KEY (DepartmentID) REFERENCES Departments(DepartmentID),
    FOREIGN KEY (ManagerID) REFERENCES Employees(EmployeeID)
);

-- 更新 Departments 表以增加外键约束
ALTER TABLE Departments
ADD CONSTRAINT fk_departments_manager
FOREIGN KEY (ManagerID) REFERENCES Employees(EmployeeID);

ER图 (参考)

![[HR Saas 人力数据管理系统-20240520004216312.webp]]

*更多详细答案可查看原文链接或关注公众号查阅。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1702288.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

shell脚本【免交互】

目录 1. Here Document 免交互 1.1 Here Document概述 1.2 实验操练 1.3 tee命令 ​1.4 变量替换 ​ 2. expect 免交互 2.2 实验操练 1. Here Document 免交互 1.1 Here Document概述 *使用I/O重定向的方式将命令列表提供给交互式程序或命令,比如 ftp、…

clickhouse——clickhouse单节点部署及基础命令介绍

clickhouse支持运行在主流的64位CPU架构的linux操作系统之上,可以通过源码编译,预编译压缩包,docker镜像和rpm等多种方式进行安装。 一、单节点部署 1、安装curl工具 yum install -y curl 2、添加clickhouse的yum镜像 curl -s https://pack…

5V降3.3V或3V恒压1A芯片WT6015

5V降3.3V或3V恒压1A芯片WT6015 WT6015 是一款采用恒定频率、电流模式架构的高效单片同步降压稳压器。该设备有可调节版本。无负 载时的电源电流为 40uA&#xff0c;关断时降至 <1uA。 2.5V 至 5.5V 输入电压范围使 WT6015 非常适合单节锂离 子电池供电的应用。 100% 占空比…

第八课,分支语句嵌套、随机数函数、初识while循环

一&#xff0c;分支结构的嵌套语法 在 Python 中&#xff0c;分支结构可以嵌套&#xff0c;这意味着你可以在一个条件语句中包含另一个条件语句。嵌套的分支结构可以让你更灵活地控制程序的逻辑流程。 怎么理解呢&#xff1f;打个比方&#xff1a;放学后&#xff0c;请三年级…

macOS上编译android的ffmpeg及ffmpeg.c

1 前言 前段时间介绍过使用xcode和qt creator编译调试ffmepg.c&#xff0c;运行平台是在macOS上&#xff0c;本文拟介绍下android平台如何用NDK编译链编译ffmepg库并使用。 macOS上使用qt creator编译调试ffmpeg.c macOS上将ffmpeg.c编译成Framework 大体思路&#xff1a; 其…

【数据结构】链式二叉树(超详细)

文章目录 前言二叉树的链式结构二叉树的遍历方式二叉树的深度优先遍历前序遍历(先根遍历)中序遍历(中根遍历)后序遍历(后根遍历) 二叉树的广度优先遍历层序遍历 二叉树链式结构接口实现二叉树结点个数二叉树叶子结点个数二叉树的深度&#xff08;高度&#xff09;二叉树第k层结…

R18 NTN中的RACH-less HO

在看R18 38.300时,发现NTN场景 增加了如下黄色字体的内容,R18 NTN支持了RACH-less HO,索性就简单看了看。 NTN RACH less HO相关的描述主要在38.331,38.213和38.321中。38.300中的描述显示:网络侧会通过RRCReconfiguration消息将RACH-less HO相关的配置下发给UE, 其中会包…

Linux入侵应急响应与排查

入侵者在入侵成功后&#xff0c;往往会留下后门以便再次访问被入侵的系统&#xff0c; 而创建系统账号是一种比较常见的后门方式。 查询特权用户特权用户(uid 为0) awk -F: $30{print $1} /etc/passwd 查找远程可以登录的账户 awk /\$1|\$5|\$6/{print $1} /etc/shadow $1&a…

仿真APP在微波加热仿真分析中的应用

一、背景介绍 微波炉是一种常用的食物加热工具&#xff0c;主要是由腔室、磁控管、波导管三个部分组成。在工作过程中&#xff0c;磁控管产生波长约为12.2cm的微波&#xff08;对应频率2.45GHz&#xff09;&#xff0c;通过波导管注入腔室内&#xff0c;在腔室内产生振荡的磁场…

echarts取消纵坐标,自定义提示内容,完整 echarts 布局代码

效果图 实现代码 开启点击柱子时的提示内容 //完整写法请看下面tooltip: {trigger: axis,axisPointer: {type: shadow}},自定义提示内容 //完整写法请看下面formatter: function (param) {// param是悬浮窗所在的数据&#xff08;x、y轴数据&#xff09;let relVal "&…

【LeeCode算法】第67题:二进制求和

目录 一、题目描述 二、初次解答 三、官方解法 四、总结 一、题目描述 二、初次解答 1. 思路&#xff1a;将a和b两个字符串转换成十进制&#xff0c;然后将相加的结果转换回文本的二进制。 2. 代码&#xff1a; char* addBinary(char* a, char* b) {int a_len strlen(a);i…

P3-P6容器之分类与各种测试

序列容器 关联式容器 这里讲到的哈希碰撞&#xff0c;是两个元素的存放位置冲突&#xff0c;用链表进行处理&#xff1b;同时hashtable的链表不能太长 以下测试程序之辅助函数 一、序列容器 array vector vector容量是两倍增长&#xff0c; 当添加元素之后&#xff0c;容…

什么样的跨网文件交换系统适合车企行业?

对于汽车行业而言&#xff0c;随着市场的全球化&#xff0c;产品和数据的跨网流通已成为常态。在这个过程中&#xff0c;跨网文件交换系统成为了连接全球供应链、加速产品开发周期、确保数据安全的不可或缺的桥梁。但什么样的系统才能真正满足车企的严苛要求呢&#xff1f;让我…

阿里通义千问大模型AI接入火车头自动生成内容插件

插件特点&#xff1a; 可以根据采集的关键词&#xff0c;自动生成文章可自定义提示词 也可以分析标题重写一个标题2个提问标签 如有需要可自由增加对话标签自己可以设置TXT关键词导入&#xff0c;自动采集生成 安装说明&#xff1a; 1.需要python环境 &#xff0c;具体可以…

【CSDN独家公开】Python解析.SchDoc格式文件转换为json文件

前情提要 因工作需求&#xff0c;需要解析.SchDoc格式文件&#xff0c;提取文本和位置关系&#xff0c;通常方式是转换为图片或PDF&#xff0c;再进行OCR&#xff0c;但是这样识别精度太低了 Github找了好些项目&#xff0c;都不支持 PyAltium不支持 https://github.com/plu…

docker安装应用

软件安装步骤可以在docker的官网查找&#xff1a; https://hub.docker.com/1.安装tomcat 这里演示用的最新版&#xff0c;版本是10.0.14 1.拉取镜像 docker pull tomcat 直接下载最新版 [rootlocalhost ~]# docker pull tomcat Using default tag: latest latest: Pulling f…

Discuz!X3.4论坛网站公安备案号怎样放到网站底部?

Discuz&#xff01;网站的工信部备案号都知道在后台——全局——站点信息——网站备案信息代码填写&#xff0c;那公安备案号要添加在哪里呢&#xff1f;并没有看到公安备案号填写栏&#xff0c;今天驰网飞飞和你分享 1&#xff09;工信部备案号和公安备案号统一填写到网站备案…

8. C++通过epoll+fork的方式实现高性能网络服务器

epollfork 实现高性能网络服务器 一般在服务器上&#xff0c;CPU是多核的&#xff0c;上述epoll实现方式只使用了其中的一个核&#xff0c;造成了资源的大量浪费。因此我们可以将epoll和fork结合来实现更高性能的网络服务器。 创建子进程函数–fork( ) 要了解线程我们先来了解…

2024新数据库入门教程

1.官网下载MySQL 下载Mysql链接: 点击下载mysql 下载完成后解压到某一个文件夹&#xff08;记住这个路径&#xff0c;一会要用到&#xff09; 2.配置初始化文件my.ini 在根目录下创建一个txt文件&#xff0c;名字叫my&#xff0c;文件后缀为ini 以下代码除安装目录和数…

C字符串和内存函数介绍(一)——长度不固定的字符串函数

前面我们一起学习了strlen&#xff0c;strcpy&#xff0c;strcmp&#xff0c;strcat的使用以及它们的模拟实现&#xff0c;它们的特点是你传参的时候&#xff0c;传过去的是数组首元素的地址&#xff0c;然后无论是计算长度&#xff0c;实现拷贝&#xff0c;相互比较还是进行追…