我正在管理数据仓库。我有几个维度表,其中大多数是类型2,有些是类型1。
我能够弄清楚如何使用MERGE来维护我的type-1维度表。
我对如何进行类型2维度表感到困惑。
如何同时执行EndDate更新和使用MERGE命令的插入?
答案 0 :(得分:2)
MERGE
不允许您对一个条件应用多个操作,或者让您在一行中多次操作。
所以,我所做的是使用INSERT INTO
结束MERGE
:
INSERT INTO DimTable
SELECT ID, Name, StartDate, null as EndDate
FROM
(
MERGE DimTable AS tgt
USING StageTable AS src
ON tgt.id = src.id AND tgt.enddate IS NULL
WHEN MATCHED THEN
UPDATE SET tgt.enddate = src.startdate
WHEN NOT MATCHED THEN
INSERT INTO (ID, Name, StartDate)
VALUES (src.id, src.name, src.startdate)
OUTPUT $action as Action, src.ID, src.Name, src.StartDate
) a
WHERE
a.Action = 'UPDATE'
密钥有OUTPUT
子句,它实际上会重定向这些行,因此您知道完全他们发生了什么。真的很棒。