批量查找和替换后需要以编程方式重新编译 DTSX 包中的所有脚本任务

dij*_*kul 2 ssis dts compilation build

我们的数据仓库即将搬迁,我们需要更改位于 DTSX 包内 VBA 脚本任务中的许多连接字符串和 UNC 文件路径。

我们已经执行了大量的查找和替换,但是当使用这种方法更改脚本任务时,在 DTSX 包执行期间运行的二进制文件不会在运行时重新编译,导致查找和替换的更改没有反映在脚本任务的执行。

我找到了一些关于如何在 SQL Server 2008 和 2012 中执行此操作的文章,但我们使用的是 SQL Server 2014,这里的代码示例对我不起作用:( https://blogs.msdn.microsoft.com /jason_howell/2013/03/05/script-component-recompile-in-sql-server-2012-integration-services-ssis-to-refresh-metadata/)。

评论中的一些问题说明了我的问题,但没有一个“我以这种方式修复[导航到路径并包含引用]”对我有用——我没有看到这些程序集,以及 2008 年之间的变化到 2012 年,现在是 2014 年,我不确定这些库是否包含在我的发行版中......

因此,我在各种子目录中有一大堆 DTSX 文件,需要重新编译它们的脚本任务,以便我们能够使用这些更改。我希望不必手动打开每个包中的每个脚本任务来强制构建每个任务。

在此先感谢您提供任何潜在的解决方案!

Hac*_*man 5

Console使用必要的代码创建了一个应用程序,以重新编译包中的每个ScriptTask内容dtsx,使用Visual Studio 2013C#达到two级别。需要引用的每个程序集的路径作为注释包含在代码中。pkgLocation是包的路径(最后我构建了一个Windows Form应用程序,但这是基本和工作代码:

  using System;
  using System.Collections.Generic;
  using System.Linq;
  using System.Text;
  using System.Threading.Tasks;

  using Microsoft.SqlServer.Dts.Design;
  using Microsoft.SqlServer.Dts.Runtime;
  using Microsoft.SqlServer.Dts.Pipeline.Wrapper;
  using Microsoft.SqlServer.Dts.Pipeline;
  using Microsoft.SqlServer.VSTAHosting;
  using Microsoft.SqlServer.IntegrationServices.VSTA;
  using Microsoft.SqlServer.Dts.Tasks.ScriptTask;
  using System.IO;

  //Libraries
  //C:\windows\Microsoft.NET\assembly\GAC_MSIL\Microsoft.SqlServer.Dts.Design\v4.0_12.0.0.0__89845dcd8080cc91\Microsoft.SqlServer.Dts.Design.dll
  //C:\Program Files (x86)\Microsoft SQL Server\120\SDK\Assemblies\Microsoft.SqlServer.DTSPipelineWrap.dll
  //C:\Program Files (x86)\Microsoft SQL Server\120\SDK\Assemblies\Microsoft.SQLServer.DTSRuntimeWrap.dll
  //C:\windows\Microsoft.NET\assembly\GAC_MSIL\Microsoft.SqlServer.IntegrationServices.VSTA\v4.0_12.0.0.0__89845dcd8080cc91\Microsoft.SqlServer.IntegrationServices.VSTA.dll
  //C:\Program Files (x86)\Microsoft SQL Server\120\SDK\Assemblies\Microsoft.SQLServer.ManagedDTS.dll
  //C:\windows\Microsoft.NET\assembly\GAC_MSIL\Microsoft.SqlServer.PipelineHost\v4.0_12.0.0.0__89845dcd8080cc91\Microsoft.SQLServer.PipelineHost.dll
  //C:\windows\Microsoft.NET\assembly\GAC_MSIL\Microsoft.SqlServer.ScriptTask\v4.0_12.0.0.0__89845dcd8080cc91\Microsoft.SqlServer.ScriptTask.dll
  //C:\windows\Microsoft.NET\assembly\GAC_MSIL\Microsoft.SqlServer.TxScript\v4.0_12.0.0.0__89845dcd8080cc91\Microsoft.SqlServer.TxScript.dll
  //C:\windows\Microsoft.NET\assembly\GAC_MSIL\Microsoft.SqlServer.VSTAScriptingLib\v4.0_12.0.0.0__89845dcd8080cc91\Microsoft.SqlServer.VSTAScriptingLib.dll

  namespace recompApp
  {
      class Program
      {
          static void Main(string[] args)
          {
              string pkgLocation;
              Package pkg;
              Application app; 

              //This is the folder where the test package lives!!
              pkgLocation =
                @"C:\TestPackage.dtsx";
              app = new Application();
              pkg = app.LoadPackage(pkgLocation, null);
              //It's Alive!!!!!!!
              try
              {

                  Executables pExecs = pkg.Executables;

                  foreach (Executable pExec in pExecs)
                  {
                      switch (pExec.GetType().Name)
                      {
                          case "TaskHost":{
                              TaskHost taskHost = (TaskHost)pExec;
                              Console.WriteLine("Executable name = " + taskHost.Name); 
                              //Script Task Outside of a Sequence
                              if (taskHost.InnerObject.ToString().Equals("Microsoft.SqlServer.Dts.Tasks.ScriptTask.ScriptTask"))
                              {
                                  ScriptTask task = (ScriptTask)taskHost.InnerObject;
                                  //Load the script project, build and save
                                  task.ScriptingEngine.LoadProjectFromStorage();
                                  task.ScriptingEngine.VstaHelper.Build("");
                                  task.ScriptingEngine.SaveProjectToStorage();
                                  //Cleanup
                                  task.ScriptingEngine.DisposeVstaHelper();
                              }                            
                              break;
                          }
                          case "Sequence":{
                              Executables seqExecs = ((Microsoft.SqlServer.Dts.Runtime.Sequence)(pExec)).Executables;
                              foreach(Executable seqExec in seqExecs){
                                  switch (seqExec.GetType().Name)
                                  {
                                      case "TaskHost":
                                          {
                                              TaskHost taskHost = (TaskHost)seqExec;        
                                              //Script Task inside a Sequence Container
                                              if (taskHost.InnerObject.ToString().Equals("Microsoft.SqlServer.Dts.Tasks.ScriptTask.ScriptTask"))
                                              {
                                                  Console.WriteLine("Executable name = " + taskHost.Name);
                                                  ScriptTask task = (ScriptTask)taskHost.InnerObject;
                                                  //Load the script project, build and save
                                                  task.ScriptingEngine.LoadProjectFromStorage();
                                                  task.ScriptingEngine.VstaHelper.Build("");
                                                  task.ScriptingEngine.SaveProjectToStorage();
                                                  //Cleanup
                                                  task.ScriptingEngine.DisposeVstaHelper();
                                              }
                                              break;
                                          }
                                  }
                              }
                              break;
                          }                        
                      }                    
                  }
                  //Save the updated xml in the package 
                  string xml;
                  pkg.SaveToXML(out xml, null);
                  File.WriteAllText(pkgLocation, xml);
              }
              catch (Exception e)
              {
                  Console.WriteLine(e.Message.ToString());
              }

              Console.WriteLine("Press any key to exit...");
              Console.ReadKey();
          }

      }
  } 
Run Code Online (Sandbox Code Playgroud)

我希望这对外面的很多人有帮助。Visual Basic如果你需要,我也有版本。