IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 数据分析SQL离职率 -> 正文阅读

[大数据]数据分析SQL离职率

离职率

  • Dimission Rate
  • 衡量企业内部人力资源流动状况 的一个重要指标
    该指标反映 企业对员工的吸引和满意情况
  • 离职率过高
    通常表明 企业的员工情绪较为波动、劳资关系存在较严重的矛盾、企业凝聚力低下…
    会导致人力资源成本增加、组织的效率下降…
  • 离职率不是越低越好
    在市场竞争中,保持一定的员工流动,有利于企业人才优胜劣汰,保持企业的活力和创新意识

计算公式

离 职 率 = 离 职 人 数 / ( 离 职 人 数 + 期 末 在 职 人 数 ) 离职率=离职人数/(离职人数+期末在职人数) =/(+)

  • 离职率范围:[0,1]

  • 时间维度:按月、按季度、按半年、按年 统计
    月 离 职 率 = 月 离 职 人 数 / ( 月 离 职 人 数 + 月 底 在 职 人 数 ) 月离职率=月离职人数/(月离职人数+月底在职人数) =/(+)
    年 离 职 率 = 年 离 职 人 数 / ( 年 离 职 人 数 + 年 底 在 职 人 数 ) 年离职率=年离职人数/(年离职人数+年底在职人数) =/(+)

示例SQL(HIVE)

WITH
-- 员工表
staff as (
    SELECT 'a1' staff_id, '2019-01-01' hire_date, NULL departure_date UNION ALL
    SELECT 'a2' staff_id, '2019-01-01' hire_date, '2020-03-01' departure_date UNION ALL
    SELECT 'a3' staff_id, '2019-01-01' hire_date, '2021-02-28' departure_date UNION ALL
    SELECT 'a6' staff_id, '2019-06-01' hire_date, NULL departure_date UNION ALL
    SELECT 'a7' staff_id, '2019-06-01' hire_date, '2020-03-02' departure_date UNION ALL
    SELECT 'a8' staff_id, '2019-07-01' hire_date, NULL departure_date UNION ALL
    SELECT 'a9' staff_id, '2019-07-01' hire_date, '2020-03-02' departure_date UNION ALL
    SELECT 'a10' staff_id, '2019-07-01' hire_date, '2020-03-02' departure_date UNION ALL
    SELECT 'a11' staff_id, '2019-07-01' hire_date, '2020-03-02' departure_date UNION ALL
    SELECT 'a12' staff_id, '2019-09-01' hire_date, '2020-03-02' departure_date UNION ALL
    SELECT 'a13' staff_id, '2020-01-01' hire_date, NULL departure_date UNION ALL
    SELECT 'a14' staff_id, '2020-03-01' hire_date, '2020-03-31' departure_date UNION ALL
    SELECT 'a15' staff_id, '2020-04-11' hire_date, NULL departure_date UNION ALL
    SELECT 'a18' staff_id, '2020-04-11' hire_date, '2021-02-28' departure_date UNION ALL
    SELECT 'a19' staff_id, '2020-04-11' hire_date, NULL departure_date UNION ALL
    SELECT 'a20' staff_id, '2020-04-11' hire_date, NULL departure_date UNION ALL
    SELECT 'a21' staff_id, '2020-04-11' hire_date, '2021-08-31' departure_date UNION ALL
    SELECT 'a22' staff_id, '2020-04-11' hire_date, '2021-08-31' departure_date UNION ALL
    SELECT 'a23' staff_id, '2020-11-01' hire_date, '2021-08-31' departure_date UNION ALL
    SELECT 'a24' staff_id, '2020-11-01' hire_date, NULL departure_date UNION ALL
    SELECT 'a25' staff_id, '2020-11-01' hire_date, NULL departure_date UNION ALL
    SELECT 'a26' staff_id, '2021-03-01' hire_date, NULL departure_date UNION ALL
    SELECT 'a26' staff_id, '2021-03-01' hire_date, NULL departure_date UNION ALL
    SELECT 'a26' staff_id, '2021-03-01' hire_date, NULL departure_date UNION ALL
    SELECT 'a31' staff_id, '2021-06-01' hire_date, NULL departure_date UNION ALL
    SELECT 'a31' staff_id, '2021-06-01' hire_date, NULL departure_date UNION ALL
    SELECT 'a33' staff_id, '2021-08-01' hire_date, NULL departure_date UNION ALL
    SELECT 'a34' staff_id, '2021-09-01' hire_date, NULL departure_date UNION ALL
    SELECT 'a34' staff_id, '2021-09-01' hire_date, NULL departure_date UNION ALL
    SELECT 'a34' staff_id, '2021-09-01' hire_date, NULL departure_date UNION ALL
    SELECT 'a34' staff_id, '2021-09-01' hire_date, NULL departure_date UNION ALL
    SELECT 'a34' staff_id, '2021-09-01' hire_date, NULL departure_date UNION ALL
    SELECT 'a34' staff_id, '2021-09-01' hire_date, '2021-09-30' departure_date UNION ALL
    SELECT 'a35' staff_id, '2021-10-01' hire_date, NULL departure_date UNION ALL
    SELECT 'a36' staff_id, '2021-11-01' hire_date, NULL departure_date
),
-- 月维度表
t AS (
    SELECT '2019-01' ym UNION ALL
    SELECT '2019-02' ym UNION ALL
    SELECT '2019-03' ym UNION ALL
    SELECT '2019-04' ym UNION ALL
    SELECT '2019-05' ym UNION ALL
    SELECT '2019-06' ym UNION ALL
    SELECT '2019-07' ym UNION ALL
    SELECT '2019-08' ym UNION ALL
    SELECT '2019-09' ym UNION ALL
    SELECT '2019-10' ym UNION ALL
    SELECT '2019-11' ym UNION ALL
    SELECT '2019-12' ym UNION ALL
    SELECT '2020-01' ym UNION ALL
    SELECT '2020-02' ym UNION ALL
    SELECT '2020-03' ym UNION ALL
    SELECT '2020-04' ym UNION ALL
    SELECT '2020-05' ym UNION ALL
    SELECT '2020-06' ym UNION ALL
    SELECT '2020-07' ym UNION ALL
    SELECT '2020-08' ym UNION ALL
    SELECT '2020-09' ym UNION ALL
    SELECT '2020-10' ym UNION ALL
    SELECT '2020-11' ym UNION ALL
    SELECT '2020-12' ym UNION ALL
    SELECT '2021-01' ym UNION ALL
    SELECT '2021-02' ym UNION ALL
    SELECT '2021-03' ym UNION ALL
    SELECT '2021-04' ym UNION ALL
    SELECT '2021-05' ym UNION ALL
    SELECT '2021-06' ym UNION ALL
    SELECT '2021-07' ym UNION ALL
    SELECT '2021-08' ym UNION ALL
    SELECT '2021-09' ym UNION ALL
    SELECT '2021-10' ym UNION ALL
    SELECT '2021-11' ym UNION ALL
    SELECT '2021-12' ym
),
-- 当期入职人数
h AS (
    SELECT
        SUBSTR(hire_date,0,7) ym,
        COUNT(hire_date) c
    FROM staff
    GROUP BY SUBSTR(hire_date,0,7)
),
-- 当期离职人数
d AS (
    SELECT
        SUBSTR(departure_date,0,7) ym,
        COUNT(departure_date) c
    FROM staff
    GROUP BY SUBSTR(departure_date,0,7)
),
-- 月维度、当期入职人数、当期离职人数
staff_count_ym AS (
    SELECT
        t.ym ym,
        NVL(h.c,0) hire_count,
        NVL(d.c,0) departure_count
    FROM t
    LEFT JOIN h ON t.ym=h.ym
    LEFT JOIN d ON t.ym=d.ym
),
-- 添加:累计入职人数、累计离职人数
staff_accumulation_ym AS (
    SELECT
        ym,
        hire_count,
        departure_count,
        SUM(hire_count) OVER(
            ORDER BY ym
            ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW
        ) hire_accumulation,
        SUM(departure_count) OVER(
            ORDER BY ym
            ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW
        ) departure_accumulation
    FROM staff_count_ym
)
-- 添加:当期在职人数、离职率
SELECT
    ym,
    hire_count,
    departure_count,
    hire_accumulation,
    departure_accumulation,
    hire_accumulation-departure_accumulation AS on_job_count,
    departure_count/(departure_count+hire_accumulation-departure_accumulation) AS dimission_rate
FROM staff_accumulation_ym;
  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-11-11 12:46:40  更:2021-11-11 12:46:44 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/18 0:42:01-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码