Pemasukan Berbilang Baris yang Cekap Menggunakan PHP dan CodeIgniter
Apabila memasukkan set data besar ke dalam jadual MySQL menggunakan PHP, adalah penting untuk mengoptimumkan proses untuk prestasi dan kecekapan. Daripada menambahkan setiap nilai baris ke dalam rentetan tunggal dan melaksanakannya, pendekatan yang lebih cekap ialah dengan memasukkan berbilang baris secara serentak menggunakan satu pertanyaan.
Pendekatan CodeIgniter
CodeIgniter rangka kerja menyediakan fungsi sisipan berasaskan tatasusunan, insert_batch(), yang memudahkan proses ini. Ia membolehkan anda menghantar tatasusunan data, setiap elemen mewakili baris yang akan dimasukkan, ke dalam satu pelaksanaan pertanyaan. Berikut ialah contoh:
$insert_data = array( array( 'name' => 'John Doe', 'email' => 'johndoe@example.com' ), array( 'name' => 'Jane Doe', 'email' => 'janedoe@example.com' ) ); $this->db->insert_batch('users', $insert_data);
Kod ini akan memasukkan kedua-dua baris ke dalam jadual pengguna dalam satu pertanyaan, memberikan peningkatan prestasi yang ketara berbanding memasukkan setiap baris secara berulang.
Mengelakkan Rentetan Mengendalikan Isu
Apabila berurusan dengan set data yang besar, adalah penting untuk mengelakkan rentetan penyatuan atau penambahan nilai terus ke dalam pernyataan SQL kerana ia boleh membawa kepada masalah ingatan dan prestasi. Sebaliknya, gunakan fungsi seperti array_map() atau implode() untuk memasang pertanyaan SQL dengan cekap.
Contohnya:
$data = array( array( 'text' => 'Row 1', 'category_id' => 1 ), array( 'text' => 'Row 2', 'category_id' => 2 ) ); $sql = array(); foreach ($data as $row) { $sql[] = '(' . $this->db->escape($row['text']) . ', ' . $row['category_id'] . ')'; } $this->db->query('INSERT INTO table (text, category_id) VALUES ' . implode(',', $sql));
Pendekatan ini membolehkan anda membina pernyataan SQL secara berperingkat, mengelakkan perkara yang tidak perlu penyalinan dan manipulasi rentetan.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Memasukkan Berbilang Baris dengan Cekap ke dalam Pangkalan Data MySQL Menggunakan PHP dan CodeIgniter?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!