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

C#-在脚本组件中填充输出列
C#-在脚本组件中填充输出列
我在脚本组件中将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以下博客中介绍了后者的方法.

上一篇:c#-BIDS和VS中的SSIS自定义控制任务调试UI


下一篇:php加了命名空间没引入初始化文件:类的命名空间要与文件夹名一致namespace Business\Event;缺少了Event