我正在管理一个数据仓库。我有几个维度表,其中大多数是类型2,还有一些是类型1。
我能够弄清楚如何使用MERGE来维护我的type-1维度表。
我对如何做类型2维度表感到困惑。
如何使用MERGE命令同时更新EndDate和插入内容?
发布于 2009-07-23 16:28:32
不幸的是,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子句,它将实际重定向这些行,这样您就可以确切地知道它们发生了什么。一个很棒的功能,真的。
https://stackoverflow.com/questions/1172696
复制相似问题