我创建了SSIS程序包,该程序遍历Excel电子表格并将数据加载到SQL中。
使用ForEach循环容器。

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

sql-server - 5次迭代后,Foreach循环容器给出错误。 SSIS-LMLPHP

我试过了:


在Foreach循环容器上将MaximumErrorCount设置为0
ValidateExternaMetadataOff上设置为OLE DB Destination


为什么要迭代5次,然后又给我一个错误?

最佳答案

他们的主要问题是


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


它与目标无关,似乎在所有工作表中都找不到New_Val$工作表

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

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命令中读取

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

关于sql-server - 5次迭代后,Foreach循环容器给出错误。 SSIS,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/48447932/

10-09 00:27