Teknik Memasukkan Data Pukal dalam MySQLi: Pengoptimuman Prestasi
Apabila berhadapan dengan tugas memasukkan volum data yang besar ke dalam pangkalan data MySQL, adalah penting untuk mempertimbangkan prestasi dan keselamatan. Semasa menggunakan penyataan yang disediakan melindungi daripada suntikan SQL, pelaksanaan naif dengan berbilang pertanyaan boleh menjadi tidak cekap.
Pendekatan Satu Pertanyaan Sebelum ini
Percubaan untuk memasukkan semua nilai sekaligus menggunakan satu pertanyaan, sambil menggoda untuk prestasi, boleh membawa kepada limpahan tindanan. Penyelesaiannya terletak pada mengoptimumkan proses sambil mengekalkan keselamatan.
Pendekatan Berasaskan Transaksi
Untuk meningkatkan prestasi dengan ketara, sertakan sisipan dalam transaksi. Ini membolehkan berbilang sisipan dianggap sebagai satu unit kerja, mengelakkan perjalanan pergi balik yang mahal ke pangkalan data.
Pengoptimuman Kod
Coretan kod berikut menggambarkan pendekatan yang dioptimumkan:
$array = ["array", "with", "about", "2000", "values"]; $query = "INSERT INTO table (link) VALUES (?)"; $stmt = $mysqli->prepare($query); $stmt->bind_param("s", $one); $mysqli->query("START TRANSACTION"); foreach ($array as $one) { $stmt->execute(); } $stmt->close(); $mysqli->query("COMMIT");
Petanda aras Keputusan
Ujian penanda aras dengan 10,000 lelaran mendedahkan peningkatan prestasi yang ketara:
Ini diterjemahkan kepada sesuatu yang luar biasa peningkatan kelajuan dua urutan magnitud, menunjukkan keberkesanan pendekatan berasaskan transaksi.
Atas ialah kandungan terperinci Bagaimanakah Transaksi Boleh Mengoptimumkan Sisipan Data Pukal dalam MySQLi untuk Prestasi Dipertingkatkan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!