【问题标题】:How capture an error like "Package Validation Error"如何捕获诸如“包验证错误”之类的错误
【发布时间】:2019-06-26 14:50:29
【问题描述】:

我要读取用户放入共享文件夹中的一些 Excel 文件。当用户更改工作表名称或更改用于共享数据的某些行或列中的位置时,会出现此问题。

在这种情况下,SSIS 会显示包验证错误。

包验证错误------------------------------包验证错误----------- - - - - - - - - - -额外的 包名 [SSIS.Pipeline] 处的 INFORMATION_Error _ Leer Staging Modelo LS2 验证失败,返回验证状态 _VS_NEEDSNEWMETADATA_.Error at PackageName [SSIS.Pipeline]_ 一个或多个组件验证失败。PackageName 出错_有 任务验证期间的错误。 (Microsoft.DataTransformationServices.VsIntegration)------------------------------BUTTONS_OK------------ ------------------

是否可以使用事件处理程序或其他选项来捕获此类错误以检测错误?

【问题讨论】:

  • 您可以做的一件事是在尝试导入文件之前编写一些东西来验证文件。然后以这种方式处理错误并在验证与您期望的不匹配时发送电子邮件或其他内容。您应该能够在 SSIS c# 脚本任务中相对轻松地执行此操作(如果您了解 c#)。

标签: sql-server validation ssis event-handling package


【解决方案1】:

您可以为数据流任务的OnError 事件添加事件处理程序,并从系统变量@[System::ErrorCode]@[System::ErrorDescription] 中读取错误描述:

如果您想了解有关事件处理程序的更多信息,请查看以下文章:


更新 1 - 解决方法

您可以使用 Script Task 使用 System.IO.File.Exists() 方法检查此 excel 文件是否存在。

然后您可以使用Microsoft.Interop.Excel 库或System.Data.Oledb 来检查 Excel 文件中是否存在工作表:

【讨论】:

  • 我尝试了事件处理程序,put is not possible to catch the Package Validation Error,另一种选择??
  • @MarcosMorales 请展示您的尝试。所以我可以帮你
  • @MarcosMorales 如果您正在寻找解决方法,请查看我的答案更新
猜你喜欢
  • 2012-05-17
  • 1970-01-01
  • 1970-01-01
  • 2018-03-28
  • 1970-01-01
  • 1970-01-01
  • 2017-12-30
  • 2021-08-26
  • 2015-08-06
相关资源
最近更新 更多