首页 > 数据库 > mysql教程 > 如何使用 C# 高效地将 DataTable 批量插入 SQL 数据库?

如何使用 C# 高效地将 DataTable 批量插入 SQL 数据库?

Patricia Arquette
发布: 2025-01-07 22:13:43
原创
529 人浏览过

How Can I Efficiently Bulk Insert a DataTable into a SQL Database Using C#?

在 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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板