SSIS - 在 OLE DB 目标中的表中填充未映射的列
Posted
技术标签:
【中文标题】SSIS - 在 OLE DB 目标中的表中填充未映射的列【英文标题】:SSIS - fill unmapped columns in table in OLE DB Destination 【发布时间】:2012-11-16 22:56:34 【问题描述】:如下图所示,我在 SQL Server 中有一个表,我通过平面文件源填充该表。我要根据下面列出的逻辑更新目标表中的两列:
SessionID - 来自第一个 CSV 导入的所有行的值都为 1;第二次导入的值为 2,依此类推。 TimeCreated - CSV 导入发生时的日期时间值。我不需要关于如何编写 TSQL 代码来完成这项工作的帮助。相反,我希望有人建议一种方法来将其实现为 SSIS 中的数据流任务。
提前感谢您的想法。
2012 年 11 月 29 日编辑
由于到目前为止的所有答案都建议在 SQL Server 端解决这个问题,所以我想向您展示我最初尝试做的事情(见下图),但它不起作用。 SSIS 将数据插入目标表后,触发器未在 SQL Server 中触发。
如果你们中的任何人能解释为什么触发器没有触发,那就太好了。
【问题讨论】:
【参考方案1】:如果您能够修改目标表,您可以让 SessionID 和 TimeCreated 的默认值为您完成所有工作。 SessionID 将是一个自动递增的整数,而 TimeCreated 的默认值将是 getdate() 或 gettime(),具体取决于数据类型。
现在,如果您确实需要在工作流程中创建值,您可以为每个值使用变量。
SessionID 将是由执行 SQL 任务设置的包变量。只需引用结果集中的变量并让 SQL 确定下一个要使用的数字。不过,这存在潜在的并发问题。
TimeCreated 很容易通过基于系统变量 StartTime 在数据流中创建派生列来完成。
【讨论】:
我最初尝试通过 SQL Server 执行此操作。我对解释我的过程的初始帖子进行了编辑。我会尝试实施你的 SSIS 解决方案 - 我会告诉你这是怎么回事。【参考方案2】:您可以使用派生列来填充TimeCreated
列,如果您想要数据流发生的时间,您只需使用日期和时间函数来获取当前日期时间。如果您想要整个包(所有文件)的公共时间戳,您可以使用系统变量@[System::StartTime]
(或所谓的)。
对于 CSV 循环(我猜),您使用 foreach 循环容器,并将迭代值映射到您在派生列中映射的用户变量 SessionID
,如上所述。
【讨论】:
【参考方案3】:首先,我最好在 SQL Server 端进行:) 但是,如果您不想或不能在服务器端这样做,您可以使用这种方法:
很明显,您需要将 SessionID 存储在某个位置,您可以为此创建一个 txt 文件,或者更好地在 SQL Server 中创建一些设置表,或者可以有其他方法。
要将列 SessionID
和 TimeCreated
添加到 OLE 目标,您可以使用 Derived columns
【讨论】:
感谢您的意见,伊戈尔。我不能将 SessionID 存储在文本文件中,因为它具有条件值。以上是关于SSIS - 在 OLE DB 目标中的表中填充未映射的列的主要内容,如果未能解决你的问题,请参考以下文章
SSIS 2005 - 在数据流中的 OLE DB 源中具有 UPDATE *和* SELECT
在 SSIS 2012 的 OLE DB 源中使用动态 SQL