Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Memasukkan 100,000 Baris dengan Cekap ke dalam Pangkalan Data MySQL?

Bagaimanakah Saya Boleh Memasukkan 100,000 Baris dengan Cekap ke dalam Pangkalan Data MySQL?

Susan Sarandon
Susan Sarandonasal
2024-12-03 11:06:13975semak imbas

How Can I Efficiently Insert 100,000 Rows into a MySQL Database?

Pemasukan Baris yang Cekap ke dalam Pangkalan Data MySQL

Memasukkan volum data yang besar ke dalam pangkalan data MySQL boleh menimbulkan cabaran dari segi kecekapan. Soalan ini meneroka prestasi dua kaedah sisipan dan menawarkan penyelesaian yang meningkatkan masa sisipan dengan ketara.

Kod awal menggunakan satu pernyataan INSERT untuk setiap baris, membawa kepada masa 40 saat untuk 100k sisipan. Untuk menambah baik ini, soalan mempertimbangkan untuk memasukkan berbilang baris secara serentak melalui DataTable/DataAdapter atau satu pernyataan INSERT dengan berbilang nilai.

Penyelesaian yang dibentangkan dalam jawapan menggunakan satu pernyataan INSERT dengan 100k baris disenaraikan sebagai nilai. Kaedah ini secara mendadak mengurangkan masa pemasukan kepada 3 saat sahaja. Pernyataan SQL yang dihasilkan adalah seperti berikut:

INSERT INTO User (FirstName, LastName) VALUES ('test','test'),('test','test'),... ;

Untuk mengelakkan suntikan kod, kaedah MySqlHelper.EscapeString digunakan untuk membersihkan nilai sebelum dimasukkan. Dengan mengelakkan pernyataan INSERT individu dan menggunakan satu pernyataan dengan berbilang nilai, proses pemasukan dipercepatkan dengan ketara.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Memasukkan 100,000 Baris dengan Cekap ke dalam Pangkalan Data MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn