使用MERGE命令更新Type-2维度

时间:2009-07-23 15:45:04

标签: sql sql-server tsql sql-server-2008 merge

我正在管理数据仓库。我有几个维度表,其中大多数是类型2,有些是类型1。

我能够弄清楚如何使用MERGE来维护我的type-1维度表。

我对如何进行类型2维度表感到困惑。

如何同时执行EndDate更新和使用MERGE命令的插入?

1 个答案:

答案 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子句,它实际上会重定向这些行,因此您知道完全他们发生了什么。真的很棒。