ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

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

2019-11-18 14:19:17  阅读:244  来源: 互联网

标签:ssis c etl


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

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有