Rumah >pembangunan bahagian belakang >tutorial php >Bagaimanakah Saya Boleh Melaksanakan Sisipan Baris Pukal dengan Cekap dalam CodeIgniter?

Bagaimanakah Saya Boleh Melaksanakan Sisipan Baris Pukal dengan Cekap dalam CodeIgniter?

DDD
DDDasal
2024-12-18 02:57:10730semak imbas

How Can I Efficiently Perform Bulk Row Insertion in CodeIgniter?

Melakukan Sisipan Baris Pukal dengan CodeIgniter

Masalah
Untuk mengelak daripada membuat pertanyaan yang sangat panjang dengan kemungkinan beribu-ribu nilai yang ditambahkan, adalah dinasihatkan untuk meneroka kaedah untuk memasukkan berbilang baris MySQL serentak menggunakan satu pertanyaan.

Penyelesaian
Memasukkan berbilang baris dalam MySQL adalah jauh lebih cekap daripada melakukan sisipan individu. Untuk mengoptimumkan proses ini dengan CodeIgniter, manfaatkan fungsi implode().

Pelaksanaan
Mulakan dengan mencipta tatasusunan untuk menyimpan pernyataan SQL anda:

$sql = array();

Seterusnya, ulangi set data anda dan bina SQL pernyataan:

foreach( $data as $row ) {
    $sql[] = '("'.mysql_real_escape_string($row['text']).'", '.$row['category_id'].')';
}

Akhir sekali, laksanakan pertanyaan menggunakan implode():

mysql_query('INSERT INTO table (text, category) VALUES '.implode(',', $sql));

Kelebihan
Pendekatan ini meminimumkan penyalinan dengan memasang pernyataan SQL dalam bahagian dan menggunakan implode() untuk menggabungkannya dengan cekap. Untuk set data dengan banyak lajur dan nilai yang berpotensi panjang, pertimbangkan untuk menggunakan gelung bersarang untuk membina pernyataan SQL secara dinamik.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Melaksanakan Sisipan Baris Pukal dengan Cekap dalam CodeIgniter?. 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