从给定的表中创建缓慢变化的维度 (SCD) 类型 2

问题描述

我正在尝试使用 sql 从下表创建一个 SCD 类型 2。

enter image description here

如果需要,单击表格以获得更好的可见性如图所示,该表格具有每位员工的每日记录。 我想创建一个包含生效日期和到期日期的类型 2。

通过使用 MERGE 使用 sql 执行此操作是最简单的方法吗?如果是这样,我将如何以保留数据完整性的方式进行处理?

感谢您的帮助!

编辑:

我没有得到指定的目标表,但我相信我的下表应该如下所示:

enter image description here

如果需要,单击表格以获得更好的可见性我还认为另一种可能性是利用 LEAD() 和 LAG() 函数来实现结果,但是在实现以下代码后,我非常接近我想要的结果,但不是正是我所需要的。我的代码和结果表如下:

SELECT employee_id,name,manager_id,CASE
    WHEN LAG(manager_id) OVER() != manager_id THEN e.date 
    WHEN e.date = FirsT_VALUE(e.date) OVER() THEN e.date
    ELSE NULL
END as "Effective Date",CASE 
    WHEN LEAD(manager_id) OVER() != manager_id THEN LEAD(e.date) OVER()
    ELSE NULL
END as "Expiration Date"
FROM employee e

enter image description here

(如果需要,点击表格以获得更好的可见性)

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)