在 C# 中使用 SqlBulkCopy 优化数据插入
对于大型数据集,将数据逐行插入到 SQL Server 数据库中效率很低。 C# 中的 SqlBulkCopy
类为批量插入操作提供了更快的替代方案。
利用 SqlBulkCopy 进行批量插入
SqlBulkCopy
旨在通过单个优化事务将大量数据传输到数据库表。 实现方法如下:
<code class="language-csharp">using System.Data.SqlClient; // Establish connection and create SqlBulkCopy object using (var bulkCopy = new SqlBulkCopy(_connection.ConnectionString, SqlBulkCopyOptions.KeepIdentity)) { // Map DataTable columns to database columns foreach (DataColumn column in table.Columns) { bulkCopy.ColumnMappings.Add(column.ColumnName, column.ColumnName); } // Specify destination table bulkCopy.DestinationTableName = destinationTableName; // Set timeout (in seconds) to prevent timeouts on large datasets bulkCopy.BulkCopyTimeout = 600; // Perform the bulk copy operation bulkCopy.WriteToServer(table); }</code>
说明:
_connection.ConnectionString
:您的数据库连接字符串。table
:包含要插入的数据的 DataTable
。destinationTableName
:SQL Server 数据库中目标表的名称。重要注意事项:
DataTable
列名称与数据库列名称精确匹配。 如果它们不同,请相应地调整 ColumnMappings
。SqlBulkCopyOptions.KeepIdentity
保留 DataTable
中的身份列值。BulkCopyTimeout
防止操作超时,这对于大量数据集尤其重要。 根据您的数据量和网络状况按需调整此值。与单行插入相比,该方法极大地提高了数据库插入速度,显着提高了处理大型数据集时的应用程序性能。
以上是如何使用 C# 高效地将 DataTable 批量插入 SQL 数据库?的详细内容。更多信息请关注PHP中文网其他相关文章!