4

我有一个父包需要多次执行同一个子包。为了让事情变得更有趣,每个实例都需要为传递给子包的父参数定义不同的值。

我使用以下脚本创建了一个脚本任务:

Microsoft.SqlServer.Dts.Runtime.Application App = new Microsoft.SqlServer.Dts.Runtime.Application();
        Package pkg = new Package();

    try
    {
        pkg = App.LoadPackage(@"\\server\SSIS Packages\ChildPackage.dtsx", null);
        pkg.Variables["ChildVariableName"].Value = Dts.Variables["AParentVariableName"].Value;
        pkg.Execute();

        Dts.TaskResult = (int)ScriptResults.Success;
    }
    catch (Exception ex)
    {
        Dts.Events.FireError(0, "Run child pkg for parent task", ex.Message, string.Empty, 0);
        Dts.TaskResult = (int)ScriptResults.Failure;
    }

问题是,我的包存储在我的 SQL 2008 R2 服务器的 SSIS 包存储中,我不知道如何引用它们;我见过的每个代码示例都是针对物理位置的。这是在 HA 集群上,因此很难维护包的物理位置。

因此,我要么需要(a)弄清楚每次启动此子包的执行包任务时如何更改 ParentVariable 的值,要么(b)弄清楚如何在 SSIS 包存储中引用正确的包,其中点我可以安全地传递正确的值。有人有想法么?

4

1 回答 1

3

代替 App.LoadPackage 方法,您将使用LoadFromSqlServer方法

app.LoadFromSqlServer("\OptionalFolderButSlashRequired\ChildPackage", "server", null, null, null);

ApplicationPackage的文档通常有我需要使用的方法的示例。

于 2013-04-05T11:51:08.690 回答