5

我们正在使用 SQL 大容量复制将近 1000 万行插入到 SQL Server 表中。

我们在 7400000 次插入后收到此异常:

链接服务器 '(null)' 的 OLE DB 提供程序 'STREAM' 返回了列 '[!BulkInsert].Amount' 的无效数据。

请让我们知道这是否可以解决。

还有内存泄漏问题。

下面是我们的代码:

try
{
            using (SqlConnection SQlConn = new SqlConnection(Common.SQLConnectionString))
            {                   
                DataTable dt1 = FillEmptyDateFields(dtDestination);

                //SqlTableCreator ObjTbl = new SqlTableCreator(SQlConn);

                //ObjTbl.DestinationTableName = DestinationTable;

                using (System.Data.SqlClient.SqlBulkCopy bulkCopy = new System.Data.SqlClient.SqlBulkCopy(SQlConn,SqlBulkCopyOptions.TableLock,null))
                {

                    //bulkCopy = new System.Data.SqlClient.SqlBulkCopy(SQlConn);
                    bulkCopy.DestinationTableName = DestinationTable;
                    bulkCopy.BulkCopyTimeout = 0;
                    bulkCopy.BatchSize = dt1.Rows.Count; // Batch Size Added.
                    Logger.Log("DATATABLE FINAL :" + dt1.Rows.Count.ToString(), Logger.LogType.Info);
                    if (SQlConn.State == ConnectionState.Closed || SQlConn.State == ConnectionState.Broken)
                        SQlConn.Open();
                    bulkCopy.WriteToServer(dt1);
                    SQlConn.Close();
                    SQlConn.Dispose();
                    bulkCopy.Close();
                    if (bulkCopy != null)
                    {
                        ((IDisposable)bulkCopy).Dispose();
                    }                        
                }
                dt1.Dispose(); 
                dt1 = null;                           
            }

            dtDestination.Dispose();
            System.GC.Collect();
            dtDestination = null;                

}
catch (Exception ex)
{
    Logger.Log(ex, Logger.LogType.Error);
    throw ex;
}
4

2 回答 2

0

根据您的代码,您似乎将 BatchSize 设置为数据表的大小,大概是 1000 万行。您可能想尝试使用类似 5000 的值。

于 2012-10-11T14:07:57.677 回答
0

也许是因为您试图将 NaN 值插入到浮点字段中?

我最近遇到了这个问题,为了找出问题所在,我只是将所有内容插入到数据类型为 NVARCHAR(MAX) 的表中,然后我注意到一个值是 NaN。

于 2014-03-04T09:09:22.600 回答