微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决从给定的表中创建缓慢变化的维度 (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 举报,一经查实,本站将立刻删除。