gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-03 15:56:21 35 4
gpt4 key购买 nike

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

我们已经执行了大规模查找和替换,但是当使用此方法更改脚本任务时,在 DTSX 包执行期间运行的二进制文件不会在运行时重新编译,导致查找和替换的更改不被执行反射(reflect)在脚本任务的执行中。

我找到了一些关于如何在 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 文件,需要重新编译它们的脚本任务,以便我们能够实现这些更改。我希望不必手动打开每个包中的每个脚本任务来强制构建每个任务。

提前感谢您提供任何可能的解决方案!

最佳答案

我创建了一个 Console 应用程序,其中包含使用 Visual Studio 2013dtsx 包中重新编译每个 ScriptTask 所需的代码C# 最多 两个 级别。需要引用的每个程序集的路径都作为注释包含在代码中。 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();
}

}
}

I hope this helps a lots of people outside. I also have the Visual Basic version if you need it.

关于build - 批量查找和替换后需要以编程方式重新编译 DTSX 包中的所有脚本任务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40160729/

35 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com