C# 访问 SSIS 的 package

原创|其它|编辑:郝浩|2009-07-06 10:54:35.000|阅读 705 次

概述:通常大家在做 BI 或者数据集成时,都会使用 SQL Job 调用 SSIS 包,但是有时候需要编程来执行包。SSIS 包有三种部署方式:文件部署,SQL Server 目录和数据库。

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

通常大家在做 BI 或者数据集成时,都会使用 SQL Job 调用 SSIS 包,但是有时候需要编程来执行包。

SSIS 包有三种部署方式:文件部署,SQL Server 目录和数据库。 

  • 文件部署方式

using DTS = Microsoft.SqlServer.Dts.Runtime;
using System.Collections;
using System.Collection.Generic;

DTS.Package dtsPackage 
= null;
DTS.Application dtsApplication 
= null;

dtsApplication 
= new DTS.Application();
//指定文件路径加载 package 
dtsPackage = dtsApplication.LoadPackage(@"c:\Package.dtsx"null);
DTS.Variables packageVariables1 
= dtsPackage.Variables;
packageVariables1[
"FirstVar"].Value = "12345321"; //传递参数 
packageVariables1[
"SecondVar"].Value = "2312";

DTS.DTSExecResult packageResult 
= dtsPackage.Execute();

SQL Server 目录


string p = @"C:\Package.dtsx";

// 1 判断 package 是否存在
Boolean folderExists = app.FolderExistsOnSqlServer("myNewFolder1""."nullnull);
Console.WriteLine(
"Folder exists? {0}", folderExists);

// 2 加载 package
DtsPackage.Package pkg = app.LoadFromSqlServer("newPkg"".", String.Empty, String.Empty, null);
DtsPackage.Variables vars2 
= pkg.Variables;
vars2[
"OpeId"].Value = "value from c#";
DtsPackage.DTSExecResult result2 
= pkg.Execute();

//3 删除包
app.RemoveFolderFromSqlServer("myNewFolder1""."nullnull);


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com

文章转载自:博客园

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP