问题描述
如果需要,单击表格以获得更好的可见性如图所示,该表格具有每位员工的每日记录。 我想创建一个包含生效日期和到期日期的类型 2。
通过使用 MERGE 使用 sql 执行此操作是最简单的方法吗?如果是这样,我将如何以保留数据完整性的方式进行处理?
感谢您的帮助!
编辑:
我没有得到指定的目标表,但我相信我的下表应该如下所示:
如果需要,单击表格以获得更好的可见性我还认为另一种可能性是利用 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
(如果需要,点击表格以获得更好的可见性)
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)