编程语言
首页 > 编程语言> > C#-在脚本组件中填充输出列

C#-在脚本组件中填充输出列

作者:互联网

File_NAME is readonly variable
MyColumn is output column
我在脚本组件中将File_Name设置为ReadOnlyVariable,我想将其存储为输出,以便以后在包中使用.在输入和输出中创建了输出列(myColumn).现在尝试将myColumn填充为File_Name

public override void CreateNewOutputRows()
{
    MyOutputBuffer.AddRow();
    MyOutputBuffer.MyColumn = ??User::FILE_NAME
}

如何将File_Name变量放在MyColumn中?

解决方法:

将脚本添加到read或read / write集合后,脚本组件允许您访问Variables集合中的SSIS变量.

这样做的语法是

MyOutputBuffer.MyColumn = Variables.FILE_NAME;

脚本任务的不同之处在于,您需要访问Value方法,然后将Object的结果值转换为正确的类型.

还有两种将FILE_NAME的值添加到数据流中的方法.第二种以SSIS为中心的方法是使用带有以下表达式的派生列组件

@[User::FILE_NAME]

假设您已将此定义为名为MyColumn的新列,并且具有类似DT_WSTR(120)的类型

另一个(假设这是平面文件源)是转到“高级”属性,并将文件名包含为一列.

如果您正在寻找激动人心的内容,我在What is the name of current file以下博客中介绍了后者的方法.

标签:ssis,c,etl
来源: https://codeday.me/bug/20191118/2028716.html