ssis源中不存在时如何在ODS中的yourvtable中添加唯一的自动增量ID

问题描述

在我的暂存区域中,有我的源表“时间表”,从中提取项目名称以将其加载到ODS中的维度“ dim-project”中。但是问题是我的源代码中没有该项目的ID。所以我必须在SSIS中生成它。 在我的暂存区域中,在从csv文件加载数据之前,我会截断表。 而且我在ODS中也做同样的事情,在从暂存区加载表之前,我将表“ dim-project”截断。 所以我的问题是如何生成维度项目的ID(在我的源代码中不存在) 并且在应用截断后不会遇到id更改的问题。

解决方法

如果您使用整数(即身份)作为ID,它将无法正常工作。由于您同时截断了暂存和ODS,因此不能保证同一行具有相同的ID。您可能想在ROW_NUMBER()上使用(按某些字段排序)来生成ID,但是在某些情况下,可以创建一个名称适合于两个旧项目的新项目,然后移动ID。

考虑使用业务密钥的哈希作为id,它将满足您的要求。如果您无法修改ID的类型,则可能需要基于散列或业务密钥来缓存ID