SSIS package 更新 variable
在Package中声明一个variable,在package运行的过程中,SSIS如何update Variable?
第一种方法:使用 Script Task 来更新Variable的值
1,创建一个variable ,VariableName是VarCode,并将变量传递到脚本的ReadWriteVariables数组中。
2,在C#脚本中,SSIS提供两种方式访问变量,第一种方式比较简单,推荐使用。
//读写变量 第一种方式
string VarName = this.Dts.Variables["User::VarName"].Value.ToString();
int VarCode = int.Parse(this.Dts.Variables["User::VarCode"].Value.ToString()); this.Dts.Variables["User::VarCode"].Value = ; //读写变量 第二种方式
this.Dts.VariableDispenser.LockForRead("User::VarName");
this.Dts.VariableDispenser.LockForWrite("User::VarCode"); Variables vars=null;
this.Dts.VariableDispenser.GetVariables(ref vars); string strName = vars["User::VarName"].Value.ToString(); int iCode = int.Parse(vars["User::VarCode"].Value.ToString()); vars["User::VarCode"].Value = ; vars.Unlock();
第二种方法:使用 Script Component 来更新Variable的值
1,创建变量
2,将变量传递到Script component中
3,使用C#脚本引用变量,在script component中引用变量有两种方式
3.1 使用变量名作为来引用变量
int code = this.Variables.VarCode;
//string name = this.Variables.VarName;
//this.Variables.VarName = "New VarName";
在引用ReadWrite类型的变量时,可能会发生异常“在PostExecute之外不能锁定变量集合进行读写访问”,就是说,不能在PostExecute函数之外通过这种方式引用ReadWrite类型的变量,如果发生这种异常,只需要将引用ReadWrite类型的变量的代码放到PostExecute中就不会出错了。
3.2使用加锁方式来引用变量,这种方式能在PostExecute函数之外引用ReadWrite类型的变量

this.VariableDispenser.LockForRead("User::VarCode");
this.VariableDispenser.LockForWrite("User::VarName"); IDTSVariables100 vars = null;
this.VariableDispenser.GetVariables(out vars); int iCode = int.Parse(vars["User::VarCode"].Value.ToString());
string strName = vars["User::VarName"].Value.ToString();
vars["User::VarName"].Value = "New VarName"; vars.Unlock();

第三种方法:通过Execute Sql Task 为变量赋值,通过Sql语句返回单行结果集,将结果集更新到接收数据的变量上。
Result Set属性:选择 Single Row
Sql Statement: 输入要赋值的sql语句 select 'ExecSqlCmd task' as Name, 2 as Code
Result Set选项卡:设置输出的单行结果和变量之间的映射关系
第四种方法:通过Execute Sql Task 为变量赋值,使用Sql赋值语句,将结果集更新到接收数据的变量上。
sql赋值语句主要有两种,select和set
declare @id int select @id=1
set @id=1
创建Package变量
配置Execute Sql Task的属性
Result Set属性:选择 None
Sql Statement: 输入sql赋值语句 select ?='ExecSqlCmd task'
在Parameter mapping中配置Direction为Output
第五种方法:使用Expression Task为变量赋值
在Expression中输入赋值的Expression。
第六种方法:为变量设置初始值,在创建变量的Variables窗体中,在Value输入的值就是变量的初始值,也可以在Expression中,使用Expression为变量赋值
SSIS package 更新 variable的更多相关文章
- 微软BI 之SSIS 系列 - 通过设置 CheckPoints 检查点来增强 SSIS Package 流程的重用性
开篇介绍 通常一个 ETL Package 是由多个控制流和数据流共同组成,有的时候 ETL 的步骤可能会比较多,整个流程执行下来的时间可能比较长.假设在 ETL Package 中包含5个Task, ...
- 微软BI 之SSIS 系列 - 利用 SSIS 模板快速开发 SSIS Package
开篇介绍 在做 ETL 项目的时候,往往很多 Package 的开发都是基于相同的模型和流程.比如在 Package 开始运行时需要向 Process Log 表中插入记录,在 Package 运行结 ...
- SSIS Package to Call Web Service
原文 SSIS Package to Call Web Service SSIS Package to Call Web Service. You can Call WebService from S ...
- How to Configure an SSIS Package to Access a Web Service using WCF
This information is from:http://blogs.msdn.com/b/dbrowne/archive/2010/07/08/how-to-configure-an-ssis ...
- SSIS 增量更新
本文转自 http://sqlblog.com/blogs/andy_leonard/archive/2007/07/09/ssis-design-pattern-incremental-loads. ...
- 效率最高的Excel数据导入---(c#调用SSIS Package将数据库数据导入到Excel文件中【附源代码下载】) 转
效率最高的Excel数据导入---(c#调用SSIS Package将数据库数据导入到Excel文件中[附源代码下载]) 本文目录: (一)背景 (二)数据库数据导入到Excel的方法比较 ...
- 一次SSIS Package的调试经历
SSIS Package的调试有时是一个非常艰难的过程,由于SSIS 编译器给出的错误信息,可能并不完善,需要程序员根据错误信息抽丝拨茧,寻找错误的根源,进而解决问题. 第一部分:SSIS提供的调试工 ...
- SQL Server(SSIS package) call .net DLL
There are two method to call .net DLL in SQLSERVER. The first one is to use the sql clr but it has a ...
- ssis package 在调试状态中设置断点,程序 不进入断点 的解决方案
原文:ssis package 在调试状态中设置断点,程序 不进入断点 的解决方案 针对 SSIS intergation 项目 > 属性 > Debug >Run64bITRunt ...
随机推荐
- [转]Java学习日记之 volatile
用在多线程,同步变量. 线程为了提高效率,将某成员变量(如A)拷贝了一份(如B),线程中对A的访问其实访问的是B.只在某些动作时才进行A和B的同步.因此存在A和B不一致的情况.volatile就是用来 ...
- babylonjs
A Babylon.js Primer Table of contents Babylon.js WebGL Game Creation System! The Browser Useful Link ...
- 嵌入式linux开发环境构建
2.1硬件环境构建 2.1.1主机与目标板结合的交叉开发模式 在主机上编辑.编译软件,然后再目标办上运行.验证程序. 对于S3C2440.S3C2410开发板,进行嵌入式Linux开发时一般可以分为以 ...
- 转:linux coredump调试
1 )如何生成 coredump 文件 ? 登陆 LINUX 服务器,任意位置键入 echo "ulimit -c 1024" >> /etc/profile 退出 L ...
- Linux系统部署体验中心
Linux系统部署体验中心 安装Linux虚拟机 1. 下载安装VMware,安装64位Linux系统(Ubuntu),要求:CPU双核,2G内存,60G硬盘 2. 安装系统时,选择安装ssh服务 ...
- [原] XAF How to bind a stored procedure to a ListView in XAF
First, I suggest that you review the following topic to learn how to show a custom set of objects in ...
- python if
根据用户从控制如输入数据,使用if语句实现用户登录功能 代码如下: name = "zy"password = "123"_name = input(" ...
- 【异常】VS中运行HTTP 无法注册URL
参考资料 http://www.java123.net/detail/view-449670.html http://www.cnblogs.com/jiewei915/archive/2010/06 ...
- 使用NPOI将数据导出为word格式里的table
开发环境:VS2013+MySQL5.5+EF6+NPOI2.0.6 格式:WinForm+CodeFirst PS:vs2013的CodeFirst很方便了啊 CodeFirst方式就不再赘述了. ...
- smartroute简单集成集群聊天通讯
在制定一个规模比较多大的聊天应用时,往往需要制定部署多个应用服务,其一可以保障服务的可靠性,其二可以增加用户负载量.但制定这样一种应用体系是一件复杂的事情,毕竟同一群体的用户实际上会在不同的服务器接入 ...