当表中有更新时,我想在维度表中查看 scd 类型二形式的历史记录,营销区域被认为更新为新值。我想在表中有更新时在维度表中查看scd类型二形式的历史记录,营销区域被认为更新为新值。我们的主要目标是根据历史数据保存更新记录方法。在 SCD-2 中更新维度表(记录数较少 - 几百条)的算法将是:FOR ALL ROWs in the SOURCE table query LOOP IF ( a corresponding row exists in the DIM TABLE THEN IF data are different THEN 1. UPDATE the ""CURRENT"" row of the DIM TABLE SET EFFECTIVE_TO = NOW ACTIVE_FLAG = 0 (ZERO) 2. INSERT new version into DIM TABLE SET EFFECTIVE_TO = NOW+1 day ahead ACTIVE_FLAG = 1 (ONE)END IF ELSE INSERT new row into DIM TABLE END IF所以我希望存储新值以及设置为标志 0 的旧值。
2 回答
data:image/s3,"s3://crabby-images/29cb2/29cb2b9dd8909a1fce9420e936215b9399d137fe" alt="?"
胡说叔叔
TA贡献1804条经验 获得超8个赞
下面是检查条件和制作 SCD-2 的块。也让我知道你到底在寻找什么。
BEGIN
LOOP cusrsor
SELECT COUNT(1)
INTO V_COUNT
FROM DIM table_name
WHERE <conditions here key columns and change fields here >
IF V_COUNT = 1 THEN -- update flag and insert new record
UPDATE stmt;
INSERT stmt;
ELSE -- New values to insert
INSERT stmt;
END IF;
END LOOP;
END;
添加回答
举报
0/150
提交
取消