本文转自:http://www.cnblogs.com/michaelxu/archive/2009/10/21/1587450.html

问题描述:执行一个存储过程得到一个多条记录的结果集,然后循环这个结果集的每一条记录,根据这条记录的某几个字段执行一个带参数的存储过程,再将返回的结果集插入到一张表中。

Execute SQL Task “Get master records”中通过执行一个存储过程得到一个主结果集,Foreach Loop Container循环每条主记录,Data Flow Task对每条记录进行处理。

1、  先定义变量,如下表

v_BatchList定义为Object用来存储返回的主结果集。v_ID, v_OptionBinary, v_OptionField以及v_OptionTable是主结果集中的部分字段,用于Data Flow Task中执行存储过程时的输入参数。

2、  双击Get master records Task,打开配置窗口,在General页一定要将ResultSet设置为Full result set,即返回整个结果集,如下图。

切换到Parameter Mapping页,将主结果集中返回的字段按需要map到相应的定义好的变量上。我们已经定义了四个变量(v_ID, v_OptionBinary, v_OptionField以及v_OptionTable)用于参数输入,记得Direction设为Output。重要的一点Parameter Name一定要是数字,并以0开始与主结果集中的字段相对应。如我的主结果集返回如下:

那么Parameter Name的对应关系为:

v_ID:  3                      //因为字段ID在结果集中3的位置

v_OptionTable: 0       //因为字段optionTable在结果集中0的位置

v_OptionField: 1        //因为字段optionField在结果集中1的位置

v_OptionBinary: 8     //因为字段optionBinary在结果集中8的位置

这个关系一定要对应好,不然得不到数据。

再切换到Result Set页,增加一个Result,Result Name一定又要设置成0,Variable Name为我们之前定义好的v_BatchList。

3、  双击Foreach Loop Container,打开设置窗口,切换到Collection页,将Enumerator设置为Foreach ADO Enumerator以循环结果集。ADO object source variable选择我们之前定义好的v_BatchList。选择Rows in the first table,如下图。

再切换到Variable Mappings页,配置变量的对应关系,如下图。其中Index跟前面的配置要对应。

4、  双击Data Flow Task,切换到Data Flow页面,这里只有两个控件,一个OLE DB Source和一个OLE DB Destination,分别用来进行数据的取出和插入,如图。

Get option records是根据前面设置的四个参数执行一个存储过程,来得到一个子记录集。

5、  双击Get option records Task,设置好Connection Manager,注意Data access mode选择SQL command用以执行存储过程,记得存储过程要在开头加上下面两句:

SET FMTONLY OFF;

SET NOCOUNT ON;。

执行存储过程语句:

EXEC [dbo].[ConvertOptionBits2Collection] ?, ?, ?,?

?代表输入的参数,这个存储过程需要四个参数。点击Parameter,打开参数设置,增加四个输入参数,注意Parameters的名字一定要与存储过程中的定义相同,Variables选择我们已经定义好的变量,这些变量道这里已经有值了,需要传入到存储过程中。另外要注意的是参数添加的顺序也要与存储过程中的定义相同,不然对应不上。或者可以在执行存储过程的语句把参数名加上。

设置完成后,点击OK完成。

6、  双击OLE DB Destination,对其进行设置,选择好Connection Manager和要插入的表,主要是Columns的对应关系,设置好之后,就可以导数据了。

[转]SSIS OLE DB Source中执行带参数的存储过程的更多相关文章

  1. [转]SSIS中OLE DB Source中如何执行Store Procedure 以得到源数据

    本文转自:http://www.cnblogs.com/michaelxu/archive/2009/10/16/1584284.html 有很多人喜欢在OLE DB Source中执行Store P ...

  2. [转]Mapping Stored Procedure Parameters in SSIS OLE DB Source Editor

    本文转自:http://geekswithblogs.net/stun/archive/2009/03/05/mapping-stored-procedure-parameters-in-ssis-o ...

  3. 在Java中调用带参数的存储过程

    JDBC调用存储过程: CallableStatement 在Java里面调用存储过程,写法那是相当的固定: Class.forName(.... Connection conn = DriverMa ...

  4. Sql Server 带参数的存储过程执行方法

    Sql Server 带参数的存储过程执行方法 Visual C# 动态操作 SQL Server 数据库实例教程(4):带参数的存储过程执行方法 上一篇文章介绍了带参数的SQL语句执行方法和不带参数 ...

  5. ThreadStart中如何带参数

    1.ThreadStart 线程执行带参数的方法,new Thread(new ThreadStart(delegate { ThreadTask(firstPage, lastPage); })); ...

  6. C# ThreadStart中如何带参数

    1.ThreadStart 线程执行带参数的方法,new Thread(new ThreadStart(delegate { ThreadTask(firstPage, lastPage); })); ...

  7. c#调用Mysql带参数的存储过程

    1.首先创建一个带参数的存储过程 ①存储过程名称=proc_bookinfo  ②存储过程2个参数 一个in 一个out in参数名称=ispay out参数名称=unPaycount ③ 这个存储过 ...

  8. oracle存储过程(带参数的存储过程)

    带参数的存储过程 举例:为指定的员工涨100元的工资,打印涨前和涨后的工资 如果带参,需要指定是输入参数还是输出参数 create or replace procedure raisesalary(e ...

  9. 如何在c#代码中执行带GO语句的SQL文件

      需要在C#代码中执行一个SQL文件的内容.遇到了两个问题: 1. 因为SQL文件中有"GO"语句,执行时报错"Incorrect syntax near 'GO'.& ...

随机推荐

  1. 使用 Visual Studio 部署 .NET Core 应用 ——ASP.NET Core 发布的具体操作

    ASP.NET Core 发布的具体操作 下面使用C# 编写的ASP.NET Core Web项目示例说明发布的全过程. 1.创建项目 选择“文件” > “新建” > “项目”. 在“添加 ...

  2. SRM 739 Div.2

    250 #include <stdio.h> #include <stdlib.h> #include <string.h> #include <iostre ...

  3. 转载--MyBaits中的#和$的区别

    面试被问到了,百度了下,原文地址:mybatis中的#和$的区别 1. #将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号.如:order by #user_id#,如果传入的值是111, ...

  4. hdu 4632(区间dp)

    Palindrome subsequence Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/65535 K (Java/ ...

  5. [BZOJ5305][Haoi2018]苹果树 组合数

    题目描述 小 C 在自己家的花园里种了一棵苹果树, 树上每个结点都有恰好两个分支. 经过细心的观察, 小 C 发现每一天这棵树都会生长出一个新的结点. 第一天的时候, 果树会长出一个根结点, 以后每一 ...

  6. hdu5782

    官方题解不是很详细 首先有一个结论:若A=pa+sa B=pb+sb A.B串循环同构,则可以构造一个可行方案(pa,sb) (sa,pb)中有一个是最长匹配,这个不难用反证法证明. 对于s1,s2串 ...

  7. electron调用C#应用程序实现串口通信

    最近转入零售行业开发了一系列产品,包含便利店收银软件.会员系统.供应链系统.为了追赶潮流,收银软件使用了electron平台开发,界面效果.开发效率确实不错:但是涉及到串口通讯时遇到了麻烦,elect ...

  8. 五十五 网络编程 UDP编程

    TCP是建立可靠连接,并且通信双方都可以以流的形式发送数据.相对TCP,UDP则是面向无连接的协议. 使用UDP协议时,不需要建立连接,只需要知道对方的IP地址和端口号,就可以直接发数据包.但是,能不 ...

  9. SpringMVC一些功能

    1.日期格式转换 当页面提交日期格式时 默认的格式为2017/10/1 如果指定日期格式为2017-10-1 //初始化绑定日期格式--不定义初始化格式时只能默认用yyyy/MM/dd格式 @Init ...

  10. 字典树&01字典树算法笔记

    1]学习了字典树之后,觉得它很明显的就是用空间来换时间,空间复杂度特别大,比如字典数单单存26个小写字母,那么每个节点的孩子节点都有26个孩子节点,字典树中的每一层都保留着不同单词的相同字母. 2]0 ...