使用c#进行odp.net批量复制

时间:2014-03-13 09:32:24

标签: c# .net oracle odp.net

我想使用odp.net的OracleBulkCopy类将数据从Microsoft Sql Server数据库复制到Oracle数据库。我有一个大约2M行和100列的表。我有内存分配问题。以下代码似乎是分配内存并且从不释放,直到它得到一个无法分配内存异常。

我使用了一个非常相似的代码,使用System.Data.SqlClient.SqlBulkCopy函数将数据从Oracle传输到MSSQL服务器,从未遇到过这种问题。

 using (SqlConnection sourceConnection =
               new SqlConnection(sourceConn))
        {

            sourceConnection.Open();
            SqlCommand commandSourceData = new SqlCommand(
              sourceSQL, sourceConnection);

            commandSourceData.CommandTimeout = 1000000;


            using (OracleConnection destinationConnection =
                       new OracleConnection(connStr))
            {
                destinationConnection.Open();
                using (OracleBulkCopy bulkCopy =
                           new OracleBulkCopy(destinationConnection))
                {

                    bulkCopy.DestinationTableName = destinationTable;  
                    bulkCopy.BatchSize = 10000;
                    bulkCopy.BulkCopyTimeout = 10000;
                    bulkCopy.WriteToServer(commandSourceData.ExecuteReader(CommandBehavior.SequentialAccess));

                }
            }
        }

当我检查内存分配时,这两个函数似乎正在使用大部分内存:

-System.Data.SqlClient.SqlDataReader.GetValue(int32)(70%) -Oracle.DataAccess.Types.DecimalConv.GetBytes(valuetype System.Decimal,native int)(20%)

有没有人知道问题的原因?

感谢。

1 个答案:

答案 0 :(得分:0)

确保显式关闭()和Dispose()您的ODP.NET对象。垃圾收集器不知道非托管代码所占用的内存。