Heim > Datenbank > MySQL-Tutorial > Wie fügt man eine Datentabelle effizient in eine SQL Server-Datenbank ein?

Wie fügt man eine Datentabelle effizient in eine SQL Server-Datenbank ein?

Susan Sarandon
Freigeben: 2025-01-07 22:40:46
Original
172 Leute haben es durchsucht

How to Efficiently Insert a DataTable into a SQL Server Database?

Batch-Einfügung von DataTable in die Datenbank optimieren

Beim Einfügen großer Datenmengen in die Datenbank ist das zeilenweise Einfügen ineffizient. Durch den Einsatz der Batch-Insertion-Technologie kann die Leistung erheblich verbessert werden.

SqlBulkCopy implementiert eine effiziente Dateneinfügung

Für SQL Server-Datenbanken bietet die SqlBulkCopy-Klasse eine effiziente Möglichkeit, eine DataTable in einem einzigen Vorgang in die Datenbank einzufügen. Diese Methode vermeidet das zeilenweise Einfügen und verkürzt die Verarbeitungszeit erheblich.

Codebeispiel

Der folgende Code zeigt, wie SqlBulkCopy verwendet wird:

<code class="language-csharp">using (var bulkCopy = new SqlBulkCopy(_connection.ConnectionString, SqlBulkCopyOptions.KeepIdentity))
{
    // 将DataTable列映射到SQL表列
    foreach (DataColumn col in table.Columns)
    {
        bulkCopy.ColumnMappings.Add(col.ColumnName, col.ColumnName);
    }

    // 设置目标表名
    bulkCopy.DestinationTableName = destinationTableName;

    // 设置超时时间(可选)
    bulkCopy.BulkCopyTimeout = 600;

    // 将DataTable插入数据库
    bulkCopy.WriteToServer(table);
}</code>
Nach dem Login kopieren

Benutzerdefinierte Zuordnung (optional)

Wenn die Spaltennamen der DataTable nicht mit den Spaltennamen der SQL-Tabelle übereinstimmen, können Sie die ColumnMappings-Eigenschaft von SqlBulkCopy für die manuelle Zuordnung verwenden.

Das obige ist der detaillierte Inhalt vonWie fügt man eine Datentabelle effizient in eine SQL Server-Datenbank ein?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage