Foreach循环容器在5次迭代后发出错误。 SSIS

时间:2018-01-25 16:42:08

标签: sql-server excel ssis etl ssis-2012

我创建了SSIS包,它迭代Excel电子表格并将数据加载到SQL中。 使用ForEach循环容器。

经过5次迭代后出于某种原因,我收到了一个错误。

enter image description here

我试过了:

  1. 在Foreach循环容器上将MaximumErrorCount设置为0
  2. ValidateExternaMetadata设置为Off
  3. 上的OLE DB Destination

    为什么它会迭代5次,之后会给我一个错误?

2 个答案:

答案 0 :(得分:1)

他们的主要问题是

  

打开" New_Val $ A3的行集:C10000"失败。检查对象是否存在于数据库中

它与目标无关,看起来在所有工作表中找不到New_Val$工作表

您可以在DataFlow任务之前添加脚本任务以检索第一个工作表名称,类似于以下逻辑:

using System;  
using System.Data;
using System.Data.OleDb;    
using Microsoft.SqlServer.Dts.Runtime;  

public class ScriptMain  
{  

    public void Main()  
    { 

        string connectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=c:\\myFolder\\excelfile.xlsx;Extended Properties=\"Excel 8.0;HDR=YES\";";

        using (OleDbConnection conn = new OleDbConnection(connectionString))
        {
            conn.Open();
            OleDbCommand cmd = new OleDbCommand();
            cmd.Connection = conn;

            // Get all Sheets in Excel File
            DataTable dtSheet = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);

            DataRow dr= dtSheet .Rows[0];

            string sheetName = dr["TABLE_NAME"].ToString();

            // You have to assign value to variable (assuming sheetName is created in SSIS)
            Dts.Variables["sheetName"].Value = sheetName ;
        }

        cmd = null;
        conn.Close();
    }
}

在Excel Source中,从表达式中使用此变量的SQL命令读取变量中的表名称

请注意,所有工作表必须具有相同的结构,否则永远不会成功

答案 1 :(得分:1)

根据我的评论:

我不认为迭代编号与它有任何关系,这里的错误很清楚:

  

打开“New_Val $ A3:C10000”的行集失败。检查数据库中是否存在该对象。

它告诉您文档中没有名为New_Val的工作表,或者文档不存在。如果您在文件上使用循环,我会猜测它正在处理的第5个文件是缺少工作表的文件。

如果你的工作表有已知的工作表名称,并且可以派生(例如由于文件的名称),我会建议不同的数据流任务,这些逻辑指向导致任务流做到正确的,取决于文件的名称。