[译]Stairway to Integration Services Level 6 - SSIS 工作流管理基础

简介

在之前的章节中,我们学习了增量载入数据. 本文中.我们通过优先约束(Precedence Constraints)来管理SSIS的工作流.

添加一个SSIS包

图 1

将新建的Package1.dtsx 改为 Precedence.dtsx  :

图 3

添加 Script Task

拖个 Script Task 到Control Flow:

图 5

Script Task估计是SSIS 里面最强大的组件了.你可以创建很多功能. 同样的,你能通过Script Task 控制SSIS工作流.

右击Script Task 点 “Edit” :

图 6

点击General ,把Name 改为“Script Task 1”:

图 8

返回 Script 页面,然后点击 ReadOnlyVariables property:

图 9

点击省略号会显示一个变量列表 .  选择 “System::TaskName” 变量 :

图 10

点击确认以后, ReadOnlyVariables 属性显示如下:

图 11

点击 “Edit Script” 按钮打开脚本编辑页面图12:

图 12

拖动滚动轴,直到你看到 Sub Main(). 然后添加如下代码 ( 我喜欢用C#….所以我图片都会更新为C#的)  :

Dim sTaskName As String = Dts.Variables("TaskName").Value.ToString

        MsgBox(sTaskName & " completed.")

图 13

在SSIS中 变量有范围,并且归于某个namespaces. 每个SSIS变量都有个Namespace. 默认有两个namespace : System 和 User  . TaskName 属于System namespace.

按F5来测试一下 :

图 14

添加第二个 Script Task

复制 Script Task 1 :

图 15

把复制了的 Script Task 1 1 改名为 “Script Task 2”:

图 16

再执行一下:

图 17

用例 0 和1

先前是一个简单用例. 示例了在没有优先约束的情况下,工作流会怎么运行. 我称之为用例 0 ( “Use Case 0”).  我们在Script Task 1 和 Script Task 2之间加个优先约束.看下用例 1 的情况. 优先约束是 Script Task1 延伸出来的一个绿色尖头. 如图 18 :

图 18

点击优先约束,然后拖到 Script Task 2:

图 19

再次执行 包, 如下图 Script Task 1 先执行 :

图 20

点击OK按钮以后,  Script Task 1 完成执行,接着 Script Task 2 开始执行:

图 21

注意:  Script Task2 是在Script Task 1 完成以后执行. 另外一个就是该优先约束默认的类型是”OnSuccess” . 也就是说. 只有成功执行Script Task 1之后,优先约束才会验证.

这点非常重要. 优先约束(originates) Script Task 1(originates) 终于 (terminates )Script Task 2. 优先约束起点为箭尾连接的任务,而箭头所指的任务为终点.

优先约束会验证一个或多个条件,如果条件为Ture 那么终端任务才会执行.

“单线程"

“单线程”就是一次执行一个东西. 使用优先约束可以在SSIS控制流中实现”单线程” . 优先约束是Control Flow中唯一设定确定工作流(deterministic workflow ) 执行顺序的方法 .

那么非确定的工作流( non-deterministic)可以在SSIS Control Flow设定么?  右击 Script Task 1 与 Script Task 2中间的优先约束,然后点击Delete.然后随意点击空白区域,按F4 调出属性(properties)面板. MaxConcurrentExecutables 用来设定当前SSIS Control Flow 可以同事执行多少个并发的任务 . 默认值是-1 . 默认的并发数量是CPU的核心数+2 .比如你有个4核CPU,那么同时可以执行6个任务.

我们把属性设为1 , 再次执行包的时候我们会看到,一次只执行了一个 Script Task :

图 22

原文连接 : http://www.sqlservercentral.com/articles/Integration+Services+(SSIS)/91649/

资源: My_First_SSIS_Project_After_Step_6.zip

时间: 2024-10-23 20:08:14

[译]Stairway to Integration Services Level 6 - SSIS 工作流管理基础的相关文章

[译]Stairway to Integration Services Level 13 -SSIS 变量回顾

介绍 在前一篇中我们组合了已经学过的事件冒泡 event bubbling, 日志记录 logging, 和父子模型 Parent-Child pattern 建立了自定义的SSIS包日志记录. 本文中, 我们会将我们的解决方案升级至 SQL Server 2012 Integration Services 并且展示 SSIS变量 (SSIS variables), 变量(variable configuration), 以及通过表达式处理动态值 (dynamic value managemen

[译]Stairway to Integration Services Level 15 – SSIS 参数回顾

介绍 在本文中我们会研究SSIS变量姐妹: SSIS 变量. 我们会演示参数配置,通过包参数管理动态属性值,然后会演示SSIS包执行的时候参数怎么被配置的. SSIS Parameters 101 SSIS参数和SSIS变量很像.  在SSIS 2012里面 变量和参数是可以互换的. 不过有重要的不同点: SSIS包开始执行以后,参数是只读的. 参数的作用域为项目或者包级别. 参数有 Sensitive 属性. 参数有 Required 属性. 因为参数在SSIS包执行的之后参数是只读的.所以参

[译]Stairway to Integration Services Level 12 - 高级日志配置

介绍 本文中,我们将结合之前学习的时间冒泡,日志记录,以及复制模型.建立一个自定义的SSIS包日志模型. SSIS Task事件回顾    Reviewing SSIS Task Events 在做实验之前我们更改一下 Precedence.dtsx SSIS 包的设置. 把 Precedence.dtsx SSIS 包的 DisableEventHandlers 属性改为True Figure 2 屏蔽内置日志   Disable Built-In Logging 首先我们要移除已经存在的日志

[译]Stairway to Integration Services Level 16 – Flexible Source Locations (多文件导入)

介绍 在本文中我们将利用SSIS参数,变量 以及 Foreach Loop Container 从多个源动态导入数据. 开始前我们先下载一些数据.WeatherData_Dec08_Apr09.zip  解压以后我们看到有三个目录数据 Figure 1 每个月年目录包含一个子目录 TH.每个TH 目录包含文件 sensor1-all.csv.  这些文件是 December 2008 至 April 2009 温度和湿度数据. February 2009 的文件包括December 2008 至

[译]Stairway to Integration Services Level 9 - Control Flow Task Errors

介绍 在本文中,我们会实验 MaximumErrorCount和ForceExecutioResult 故障容差属性,并且还要学习Control Flow task errors, event handlers 和 containers 的联系 关于 SSIS Task Errors 打开 Precedence.dtsx 包. 你的Control Flow 显示如下: 图 1 再做测试前我们先调整两个优先约束.   Script Task 4 和 Script Task 3  调整如下: 图 2

[译]Stairway to Integration Services Level 18 – 部署和执行

介绍 在本文中,我们要创建一个SSIS Catalog 实例,部署我们的项目,并且运行 weather data loader 包. SSIS 2012 部署模型   SSIS 2012 Deployment Models SQL Server 2012 Integration Services 支持两种部署模型: 包部署模型  Package Deployment Model 项目部署模型  Project Deployment Model 包部署模型是向后兼容的,支持SSIS 2012以前的

[译]Stairway to Integration Services Level 3 - 增量导入数据

让我们打开之前的项目:My_First_SSIS_Project_After_Step_2.zip 之前项目中我们已经向dbo.contact 导入了19972行,如果再次执行包会重复导入,让我们来解决这个问题. 增量导入目标 (Incremental Load Goals) 在我们批量处理之前,先来明确下增量导入的目标: 如果数据源中有新纪录,我们要把这些记录导入目的地. 如果数据源中有记录变更,我们要把之前导入目的地的相关记录更新. 如果数据源中的记录被删除,我们要把之前导入目的地的相关记录

[译]Stairway to Integration Services Level 10 - 高级事件活动

介绍 在前一篇文章中我们介绍了故障容差相关的 MaximumErrorCount 和 ForceExecutionResult 属性.  同时我们学习了SSIS Control Flow task errors, containers, 和event handlers联系 . 本篇中我们关注事件行为. 我们用两种方法操纵日志传递(冒泡)行为. 同时也介绍父子模式(Parent-Child pattern )并且演示事件在父子模式中的行为. 关于 SSIS 任务事件 About SSIS Task

[译]Stairway to Integration Services Level 14 - 项目转换(SSIS 2008 ~ SSIS 2012)

介绍 本文中我们会用SSDT把第一个SSIS项目转换为 SSIS 2012, 为什么要升级到2012? 你可能想使用SSIS 2012新的特性. 又或者想使用 SSIS 2012 Catalog. 想要使用 Catalog, 你的项目必须转为 Project Deployment Model 我们会在本片文章中演示. 开发模型  Deployment Models 在Solution Explorer,里面我们注意到一段文字“(package deployment model)” : Figur