残念ながら、パッケージを開くか、DTExec Utility
を使用してパッケージを実行しない限り、統合サービスソリューション(Visual Studio内)からこれを実現する方法はありません。 。ただし、いくつかの回避策を実行して、プログラムでエラーを取得することを確認できます。
回避策
- Visual Studioを使用して(Vb.Netを使用して)winformsアプリケーションを作成しました
-
Microsoft.SqlServer.DTSPipelineWrap
を追加しました およびMicrosoft.SQLServer.ManagedDTS
参考として -
次のコードを使用して、特定のディレクトリ内のパッケージをループし、検証して、エラーをログファイルに記録しました。
Dim strPackagesDirectory As String = "C:\Users\Admin\Desktop\New folder" Dim strOutputLogFile As String = "D:\1.txt" For Each strFile As String In IO.Directory.GetFiles(strPackagesDirectory, "*.dtsx", IO.SearchOption.TopDirectoryOnly) Dim pckg As New Microsoft.SqlServer.Dts.Runtime.Package Dim app As New Microsoft.SqlServer.Dts.Runtime.Application pckg = app.LoadPackage(strFile, Nothing) Dim obj = pckg.Validate(Nothing, Nothing, Nothing, Nothing) If pckg.Errors.Count > 0 Then Using sr As New IO.StreamWriter(strOutputLogFile, True) sr.WriteLine("") sr.WriteLine(strFile) sr.WriteLine("--------------") For Each err As Object In pckg.Errors sr.WriteLine(err.Description) Next sr.WriteLine("==========") sr.Close() End Using End If Next
参考資料
- https://msdn.microsoft.com/en-us/library/ms136090.aspx?cs-save-lang=1&cs-lang=vb#code-snippet-1
- https://msdn.microsoft.com/en-us/library/microsoft.sqlserver.dts.runtime.package.aspx
- https://msdn.microsoft.com/en-us/library/microsoft.sqlserver.dts.runtime.dtscontainer.validate.aspx