2

我正在开发一个 2008R2 SSIS 包,它需要读取 CSV 并使用 Oracle 包将行插入到 oracle 数据库中:

我正在使用“OLE DB 的 Oracle 提供程序”(OraOLEDB.Oracle.1)和“OLE DB 命令”与数据库进行通信。

我可以成功地将我的参数映射到查询并插入行。如果 Oracle 包返回错误,我遇到的问题与捕获来自 oracle 的错误响应有关。

当我将“OLE DB 命令”组件设置为“重定向行”时,将通过管道传输到我的结果集中的行,但错误描述似乎是通用的,并且没有提供与 Oracle DB 产生的实际错误相关的任何信息包边。我得到“命令执行产生错误。”

见截图:

错误行 - 捕获的一般错误

我在脚本组件中使用此代码块并在我的重定向行中添加额外的输出来获得错误描述:

 public override void Input0_ProcessInputRow(Input0Buffer Row)
{
   Row.ErrorDescription = this.ComponentMetaData.GetErrorDescription(Row.ErrorCode);


}

我知道这不是实际的错误,因为当我将 OLE DB 命令设置为使组件出错而不是重新定向行时,我可以在 Package Progress 选项卡上看到我需要捕获的实际错误。

见截图: 在此处输入图像描述

有谁知道捕获这些错误的方法,因为它们似乎已被错误行重定向所吞噬?

4

1 回答 1

0

你想如何处理错误?

  1. 如果您只是对完整详细地记录它们感兴趣,则可以将日志记录设置到表或文件中。
  2. 如果您想对它们做一些“有趣”的事情但仍将它们视为错误,则可以使用错误事件处理程序(将引发多个事件,其中一个包含详细消息)。
  3. 如果这些都不能完全满足您的需求,您始终可以将 OLE DB 命令组件替换为脚本组件,您可以在其中手动执行命令并捕获生成的异常。

选项 1 和 2 有据可查;选项 3 涉及更多,并且仅在您希望以完全自定义的方式从单个行中的错误中恢复的高级场景中才需要。样本:

public override void Input0_ProcessInputRow(Input0Buffer Row) {
    try {
        using (var connection = (OleDbConnection) Connections.Connection.AcquireConnection(null)) {
            using (var command = connection.CreateCommand()) {
                command.CommandText = "TwiddleKnob";
                command.CommandType = CommandType.StoredProcedure;
                command.Parameters.Add("@p0", OleDbType.VarChar, 50).Value = Row.Name;
                command.ExecuteNonQuery();
            }
        }
    } catch (OleDbException e) {
        Row.ErrorDescription = e.Errors.Count > 0 ? e.Errors[0].Message : e.Message;
    }
}

这里脚本组件必须配置一个连接管理器和一个带有“ErrorDescription”列的输出。如果发生数据库错误,我们直接处理。尽管具有最大的灵活性,但它有一个明显的缺点,即要求您编写手动代码来执行语句,这反而违背了使用 SSIS 的意义。通常,日志记录或事件处理都可以满足您的需求。

于 2015-02-24T00:44:15.520 回答