我有一个父包需要多次执行同一个子包。为了让事情变得更有趣,每个实例都需要为传递给子包的父参数定义不同的值。
我使用以下脚本创建了一个脚本任务:
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 包存储中引用正确的包,其中点我可以安全地传递正确的值。有人有想法么?