Heim >Datenbank >MySQL-Tutorial >Wie optimiert man das Laden von Massendaten aus DataTable in MySQL mit MySqlBulkLoader?
Frage:
Zuvor mit Microsoft SQL Server Massendateneinfügung wurde nahtlos mit der SqlBulkCopy-Klasse ausgeführt. Wie kann eine ähnliche Funktionalität in MySQL unter Berücksichtigung von Leistungsaspekten erreicht werden?
Antwort:
Annahmen vermeiden:
Betonung Angesichts der Bedeutung evidenzbasierter Entscheidungsfindung widerlegt die Antwort die Annahme, dass das Schreiben einer DataTable in eine CSV-Datei vor dem Massenladen in MySQL zu einer schlechten Leistung führen würde.
MySqlBulkLoader übertrifft:
In einer Reihe von Tests übertraf die MySqlBulkLoader-Klasse die standardmäßigen MySQL-Datenadapteraktualisierungen innerhalb einer Transaktion erheblich und schloss das Einfügen von 100.000 Zeilen in nur 5–6 Sekunden ab.
Codelösung :
Um den MySqlBulkLoader effektiv zu nutzen:
<code class="csharp">// Create a temporary CSV file string tempCsvFileSpec = @"C:\Users\Gord\Desktop\dump.csv"; using (StreamWriter writer = new StreamWriter(tempCsvFileSpec)) { Rfc4180Writer.WriteDataTable(rawData, writer, false); } // Perform bulk loading with MySqlBulkLoader var msbl = new MySqlBulkLoader(conn); msbl.TableName = "testtable"; msbl.FileName = tempCsvFileSpec; msbl.FieldTerminator = ","; msbl.FieldQuotationCharacter = '"'; msbl.Load(); // Cleanup System.IO.File.Delete(tempCsvFileSpec);</code>
Das obige ist der detaillierte Inhalt vonWie optimiert man das Laden von Massendaten aus DataTable in MySQL mit MySqlBulkLoader?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!