首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用MERGE命令更新Type-2尺寸

使用MERGE命令更新Type-2尺寸
EN

Stack Overflow用户
提问于 2009-07-23 15:45:04
回答 1查看 1.8K关注 0票数 1

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

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

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

如何使用MERGE命令同时更新EndDate和插入内容?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2009-07-23 16:28:32

不幸的是,MERGE不允许您对一个条件应用多个操作,也不允许您对一行进行多次操作。

所以,我要做的就是使用一个INSERT INTO来包装MERGE

代码语言:javascript
复制
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子句,它将实际重定向这些行,这样您就可以确切地知道它们发生了什么。一个很棒的功能,真的。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1172696

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档