[译]Stairway to Integration Services Level 15 – SSIS 参数回顾
介绍
在本文中我们会研究SSIS变量姐妹: SSIS 变量. 我们会演示参数配置,通过包参数管理动态属性值,然后会演示SSIS包执行的时候参数怎么被配置的.
SSIS Parameters 101
SSIS参数和SSIS变量很像. 在SSIS 2012里面 变量和参数是可以互换的. 不过有重要的不同点:
- SSIS包开始执行以后,参数是只读的.
- 参数的作用域为项目或者包级别.
- 参数有 Sensitive 属性.
- 参数有 Required 属性.
- 因为参数在SSIS包执行的之后参数是只读的.所以参数值无法通过表达式组合.
项目参数 Project Parameters
项目参数可以被SSIS项目中所有包使用. 不过他们必须在Project Deployment 模型中使用.
Project Deployment 是 SQL Server 2012 Integration Services新功能. 项目参数是Project Deployment 模型的新特性之一. 其他特性包括包参数, 项目连接管理器, 以及部署到新的 SQL Server 2012 Integration Services Catalog.
在Solution Explorer, 双击Project.params 对象:
Figure 3
项目参数窗口工具栏有三个按钮:
- Add Parameter
- Delete Parameter
- Add Parameters to Configurations
Add Parameter
点击Add Parameter按钮添加一个新的项目参数到 My_First_SSIS_Project SSIS 项目:
Figure 4
“Parameter” 被添加到 SSIS 项目. 参数默认属性如下:
- Data Type: Int32
- Value: 0
- Sensitive: False
- Required: False
- Description: [Empty String]
对比了一下参数数据类型和变量数据类型.:
- Boolean
- Byte
- DateTime
- Decimal
- Double
- Int16
- Int32
- Int64
- SByte
- Single
- String
- UInt32
- UInt64
下面三个是变量特有的数据类型:
- Char
- DBNull
- Object
Sensitive(敏感) 属性是一个布尔值默认为 False. 设置为True把变量值标记为敏感的. 如果为 True, SQL Server 2012 Integration Services 会加密这个值. 这取决于 ProtectionLevel 属性的设置. 可以在项目属性里面进行配置
Figure 7
Figure 8
注意: 参数的Sensitive 属性一旦被设置为True , Value值就会被掩盖.
Required 属性也是布尔值,默认为 False. 当值为False的时候表示SSIS 项目执行时并非必要,若设置为True,则该值必须提供SSIS项目执行时使用(必须有值).
为了演示目的,配置如下:
- Name: Parameter
- Data Type: Int32
- Value: 0
- Sensitive: True
- Required: True
- Description: Test Parameter
Figure 9
包参数 Package Parameters
包参数可以在参数标签上配置:
Figure 13
开始配置SSIS包参数之前先下载点真实数据 WeatherData_Dec08.zip
建立个新的包变量 SourceFilePath
Name: SourceFilePath
- Data Type: String
- Value: <the location of sensor1-all.csv on your system>
- Sensitive: False
- Required: True
- Description: Weather data source file
Figure 16
返回Control Flow添加一个Data Flow Task 然后重命名至“DFT Stage Temperature and Humidity” :
Figure 18
双击 “DFT Stage Temperature and Humidity” 拖一个 Flat File Source 然后改名为“FFSrc Temperature and Humidity”:
Figure 19
双击FFSrc Temperature and Humidity 然后创建连接管理器 ,把连接管理器的名字改为“FFCM Temperature and Humidity.” 选择你刚才下载的sensor1-all.csv 文件
Figure 28
完成后如下 :
Figure 29
在SQL Server里面创建一个数据库.
Use master
go
If Not Exists(Select name
From sys.databases
Where name = 'WeatherData')
begin
print 'Creating database WeatherData'
Create Database WeatherData
print 'WeatherData database created'
end
Else
print 'WeatherData database already exists.'
Listing 1
再拖一个 OLE DB Destination ,然后重命名为 “OLEDest Stage Temperature”:
Figure 35
双击 “OLEDest Stage Temperature” 创建连接管理器与刚才建立的 WeatherData数据库连接:
Figure 41
表格名称改为StageTemperature
Figure 42
点击“FFCM Temperature and Humidity”平面文件连接管理器,然后他属性里面把 Expressions的 ConnectionString 属性设置为 SourceFilePath 包参数 :
Figure 48
按F5执行包,结果如下:
Figure 55
如果一切都没问题,那么你的执行结果会和 Figure 55 相同.
现在把 sensor1-all.csv 移到上级目录 Dec08 下 :
Figure 56
再次执行包..会出现类似下面的报错:
Figure 57
停掉 debugger. 修正 SourceFilePath 的路径:
Figure 58
现在再次运行包 :
Figure 59
测试成功
原文链接: http://www.sqlservercentral.com/articles/Integration+Services+(SSIS)/106428/
[译]Stairway to Integration Services Level 15 – SSIS 参数回顾的更多相关文章
- [译]Stairway to Integration Services Level 13 - SSIS 变量回顾
介绍 在前一篇中我们组合了已经学过的事件冒泡 event bubbling, 日志记录 logging, 和父子模型 Parent-Child pattern 建立了自定义的SSIS包日志记录. 本文 ...
- [译]Stairway to Integration Services Level 8 - SSIS 工作流管理高级
介绍 在前两个章节我们,建立了一个新的SSIS包,简单的使用了一下scripting还有优先约束,并且测试了MaxConcurrentExecutables 属性. 同时实验了 “On Succe ...
- [译]Stairway to Integration Services Level 6 - SSIS 工作流管理基础
简介 在之前的章节中,我们学习了增量载入数据. 本文中.我们通过优先约束(Precedence Constraints)来管理SSIS的工作流. 添加一个SSIS包 图 1 将新建的Package1. ...
- [译]Stairway to Integration Services Level 7 - SSIS 工作流管理中级
介绍 前一个章节我们对SSIS的优先约束做了初步了解,并且实验了MaxConcurrentExecutables 包属性的设置. 本文将测试“On Success”, “On Completion”, ...
- [译]Stairway to Integration Services Level 16 – Flexible Source Locations (多文件导入)
介绍 在本文中我们将利用SSIS参数,变量 以及 Foreach Loop Container 从多个源动态导入数据. 开始前我们先下载一些数据.WeatherData_Dec08_Apr09.zip ...
- [译]Stairway to Integration Services Level 12 - 高级日志配置
介绍 本文中,我们将结合之前学习的时间冒泡,日志记录,以及复制模型.建立一个自定义的SSIS包日志模型. SSIS Task事件回顾 Reviewing SSIS Task Events 在做实 ...
- [译]Stairway to Integration Services Level 9 - Control Flow Task Errors
介绍 在本文中,我们会实验 MaximumErrorCount和ForceExecutioResult 故障容差属性,并且还要学习Control Flow task errors, event han ...
- [译]Stairway to Integration Services Level 18 – 部署和执行
介绍 在本文中,我们要创建一个SSIS Catalog 实例,部署我们的项目,并且运行 weather data loader 包. SSIS 2012 部署模型 SSIS 2012 Deploy ...
- [译]Stairway to Integration Services Level 11 - 日志配置
介绍 在前一个章节我们讨论了事先行为,分享了如何操作默认的行为和时间冒泡,并且介绍了父子模型. 本文中,我们会配置SSIS日志. 进行简单及高级日志配置,存储,和检索的实验.并且生成自定义日志信息. ...
随机推荐
- vb ——ini 配置文件
最近在学校VB 开发点小东西, 使用ini配置文件要用到下边连个函数 GetPrivateProfileString (从配置文件得到信息)百度百科的介绍http://baike.baidu.com/ ...
- Jsoup代码解读之四-parser
Jsoup代码解读之四-parser 作为Java世界最好的HTML 解析库,Jsoup的parser实现非常具有代表性.这部分也是Jsoup最复杂的部分,需要一些数据结构.状态机乃至编译器的知识.好 ...
- NYOJ541 最强DE 战斗力(第五届省赛试题)
最强DE 战斗力 时间限制:1000 ms | 内存限制:65535 KB 难度: 描述 春秋战国时期,赵国地大物博,资源非常丰富,人民安居乐业.但许多国家对它虎视眈眈,准备联合起来对赵国发起一场 ...
- iOS 按钮倒计时功能
iOS 按钮倒计时功能, 建议把按钮换成label,这样会避免读秒时闪烁 __block ; __block UIButton *verifybutton = _GetverificationBtn; ...
- 一些tcp通讯代码
1,nginx-lua 需要设置nginx配置文件 resolver 223.5.5.5 223.6.6.6; lua_package_path "/usr/local/nginx/conf ...
- 百度 LBS 开放平台,开发人员众測计划正式启动
Hi各位亲爱滴开发人员: 你是否以前-- 期望第一时间率先接触到百度LBS开放平台的最新功能? 期望被邀请作为最最尊贵的首批试用志愿者感受志愿者的特权? 期望自己的意见被产品经理採纳.优化功能.从 ...
- POJ 1556 The Doors(计算几何+最短路)
这题就是,处理出没两个点.假设能够到达,就连一条边,推断可不能够到达,利用线段相交去推断就可以.最后求个最短路就可以 代码: #include <cstdio> #include < ...
- centos6.5设备mysql5.6
1. 首先检查版本号number # uname -a 要么 # cat /etc/redhat-release CentOS release 6.6 (Final) 2. 下载并安装Mysql的yu ...
- linux线程之pthread_join和pthread_detach
在任何一个时间点上,线程是可结合的(joinable)或者是分离的(detached).一个可结合的线程能够被其他线程收回其资源和杀死.在 被其他线程回收之前,它的存储器资源(例如栈)是不释放的.相反 ...
- js中this指向问题
1.在全局范围内使用this的时候 它指向的是全局对象 this Window {top: Window, window: Window, location: Location, external: ...