SSIS - 4.使用表达式任务和脚本任务实现更改变量和输出变量值
一、脚本任务
脚本任务是SSIS包中功能很强大的组件,尤其当内置的任务无法实现我们需要的功能的时候,我们都可以使用脚本任务来实现。脚本任务使用VSTA(Microsoft Visual Studio Tools for Applications)作为开发和执行环境,所以在执行包时一定要先安装VSTA。
使用脚本任务更改自定义变量V1,V2的值分别为3和5,输出系统变量和自定义变量的值,具体步骤:
1.打开SSIS包,从SSIS 工具箱中将脚本任务拖放到包中,右键脚本任务->选择“编辑”

2.此时,打开脚本任务编辑器如下:
1)脚本语言:可以选择VB或者C#
2)入口点:这是脚本开发的执行方法,默认是Main
3)只读变量:指定脚本要用到的只读变量
4)读写变量:指定脚本要用到的读/写变量

3.选择“Microsoft Visual C# 2012”作为脚本语言,单击只读变量最后的...按钮打开"选择变量"窗口如下,我们选择图中4个变量然后单击OK,同样的,我们打开读写变量最后的"..."按钮选择之前定义的变量V1,V2,V3,然后单击OK.

4.单击常规页修改下任务名称和描述如下:

5.在表达式页,可以使用表达式结果修改任何属性的值.上面设置完成后,编辑器如下:

6.单击"编辑脚本..."按钮打开VSTA,添加下面的Code后单击OK保存设置.

7.使用下面4种方式来执行包.
1)单击菜单中的"调试"->"开始调试"
2)按F5
3)但是绿色三角"Start"按钮
4)在解决方案资源管理器中右键包,之后选择"执行包"

8.代码说明:
1)在C#代码中,变量可以用这种格式调用:Dts.Variable[" "].Value
2)95~98行:为了输出系统变量
3)101~102行:修改自定义变量V1,V2的值
4)105行:因为V3是通过表达式使用V1和V2的值计算出来的,因为V1和V2在101~102行被修改了,所以这导致V3不稳定,无法输出,只有等这个脚本任务结束之后,V3才可用.所以这行被注释掉了.
二、表达式任务
我们可以使用表达式任务解决上面V3无法在脚本任务中输出的问题。我们先使用表达式任务改变V1,V2 的值,再使用脚本任务输出,具体步骤如下:
1.从SSIS 工具箱中拖一个表达式组件放到脚本任务的上方,如下:

2.在属性窗口中更改表达式任务的组件名称为“Change V1”
3.右键表达式任务->选择“编辑...”打开编辑表达式窗口如下:

4.此时,我们可以拖放变量,函数和操作运算到表达式编辑区域来创建表达式。这里,我们把变量V1 拖放到表达式编辑区,在后面填写"=abc",然后单击“计算表达式”按钮,之后会出现下面的错误提示。

5.更改“abc”为2,然后单击“计算表达式”按钮,可以计算出值“3”,之后单击OK。

6.重复上面的步骤更改变量V2的值为“5”,或者,也可以直接复制上面已经完成的表达式任务,对其名称和表达式进行修改,改完之后,如下图:

7.选中最上面的"Change V1"的表达式任务,可以看到下面有个蓝色的箭头,将箭头拖拉到下一个表达式任务"Change V2"上,之后再从"Change V2"上拉一个箭头到下面的脚本任务上。

8.编辑脚本任务,将V1,V2,V3变量改为只读变量,修改代码如下:

9.保存脚本后,执行包,就可以输出系统变量及V1,V2,V3的值了。

10.最后,单击“OK”或“停止调试”或按“F5”来关闭包的执行。
SSIS - 4.使用表达式任务和脚本任务实现更改变量和输出变量值的更多相关文章
- 如何在SSIS的脚本组件中访问变量
原文:如何在SSIS的脚本组件中访问变量 这是一个小问题,我们在SSIS的设计中很多地方都会用到变量,我习惯性地将"变量"和"表达式"称为SSIS的灵魂,虽然不 ...
- Shell脚本获得变量值作为新变量一部分的值
最近使用shell写一个发布脚本时,由于shell编程是边学便用的缘故,经验不足,中间遇到一个问题,一个变量的值作为一个新变量的一部分,而我要根据变量获得新变量的值,以前没有遇到过.网络搜索一番,最后 ...
- Ant 脚本打印系统属性变量、ant内置属性
Ant 脚本打印系统属性变量.ant内置属性 作用 编写ant脚本的时候,经常会引用到系统属性,本脚本用于打印系统常用属性(System.getProperties)与环境变量(Environment ...
- ssis 到别的表查找临时变量值
原文:ssis 到别的表查找临时变量值 etl过程过,往一个数据库表插入数据,插入的值往往需要到另外一个数据库读取.例如下面的客户跟踪,需要一个"项目ID",这个ID需要到另一个数 ...
- loadrunner 脚本开发-int型变量和字符串的相互转换
脚本开发-int型变量和字符串的相互转换 by:授客 QQ:1033553122 字符串转化为int型变量 Action2() { int j = 0; j = atoi("12345&qu ...
- 在python脚本中设置环境变量,并运行相关应用
1. 问题 在自动化应用的时候 ,有时候环境变量与运行需要不一致.这时候有两种选择: 改变节点环境变量,使得其和运行需求保持一致: 在自动化脚本中设置环境变量,其范围只在脚本运行环境中有效. 显然,当 ...
- shell脚本中特定符合变量的含义
shell脚本中特定符合变量的含义: $# 传递到脚本的参数个数 $* 以一个单字符串显示所有向脚本传递的参数.与位置变量不同,此选项参数可超过9个 $$ 脚本运行的当前进程PID号 ...
- centos shell编程5 LANMP一键安装脚本 lamp sed lnmp 变量和字符串比较不能用-eq cat > /usr/local/apache2/htdocs/index.php <<EOF重定向 shell的变量和函数命名不能有横杠 平台可以用arch命令,获取是i686还是x86_64 curl 下载 第三十九节课
centos shell编程5 LANMP一键安装脚本 lamp sed lnmp 变量和字符串比较不能用-eq cat > /usr/local/apache2/htdocs/ind ...
- loadrunner脚本中参数化和返回值输出log到外部文件
loadrunner脚本中参数化和返回值输出log到外部文件 很多时候,我们在做性能测试之前,需要造数据,但是使用的这些参数化数据和生成的返回数据在后面的测试都会用的,所以我们需要在造数据过程中,将参 ...
随机推荐
- [Linux]不可重入函数
一.概述 怎么会有可重入和不可重入. 在多任务系统下,中断可能在任务执行的任何时间发生:如果一个函数的执行期间被中断后,到重新恢复到断点进行执行的过程中,函数所依赖的环境没有发生改变,那么这个函数就是 ...
- 后端api规范说明文档
我们此次后端api的实现主要是按照RESTful api规范来设计的,就是符合REST架构下设计api的规范.简单的来说REST结构就是:利用URL定位资源,用HTTP动词(GET,POST,PUT, ...
- Mac上重置mysql 5.7密码
Mac上重置mysql 5.7密码 >我的mac系统是osx 10.12 装完mysql5.7之前根本登录不上,网上说用DMG方式装完后,后弹出一个框,上面会有临时密码,但是我安装的时候却手一抖 ...
- SpringBoot 整合 Redis缓存
在我们的日常项目开发过程中缓存是无处不在的,因为它可以极大的提高系统的访问速度,关于缓存的框架也种类繁多,今天主要介绍的是使用现在非常流行的NoSQL数据库(Redis)来实现我们的缓存需求. Spr ...
- Git 的使用(皮毛))
1.安装git 软件(下一步直到完成) 2.码云注册(保存代码) 3.创建代码托管仓库 4.创建文件夹 5.写东西并提交到码云 1.在某个文件夹下写东西 2.写完之后在此文件夹下鼠标右键,并选择[gi ...
- ssh 连接不上报Connection closed by remote host
解决办法 (1)查看这两个文件是否有阻止cat /etc/hosts.deny cat /etc/hosts.allow (2)客户端连接数过多修改/etc/ssh/sshd_config中#MaxS ...
- Nginx 文件下载 apk 文件下载不了
通过nginx 做下载服务器 下载 apk 安装包, 出现错误502和 499. 解决办法在 nginx的 mime.types 中 来自为知笔记(Wiz)
- 记忆(缓存)函数返回值:Python 实现
对于经常调用的函数,特别是递归函数或计算密集的函数,记忆(缓存)返回值可以显着提高性能.而在 Python 里,可以使用字典来完成. 例子:斐波那契数列 下面这个计算斐波那契数列的函数 fib() 具 ...
- redis对set(无序集合)的相关操作
redis对set类型(无序集合)操作的相关命令以及如何在python使用这些命令 redis对set类型操作的命令: 命令 语法 概述 返回值 Redis Sadd 命令 sadd key memb ...
- 【转】HTML CANVAS
https://blog.csdn.net/u012468376/article/details/73350998 学习HTML5 Canvas这一篇文章就够了 2017年06月16日 20:57:4 ...