Rumah >pangkalan data >tutorial mysql >Bagaimanakah Kelas Model CodeIgniter Boleh Mengoptimumkan Sisipan Pangkalan Data Pukal?

Bagaimanakah Kelas Model CodeIgniter Boleh Mengoptimumkan Sisipan Pangkalan Data Pukal?

Patricia Arquette
Patricia Arquetteasal
2024-12-15 19:00:15537semak imbas

How Can CodeIgniter's Model Class Optimize Bulk Database Inserts?

Sisip Pukal menggunakan Kelas Model CodeIgniter

Memasukkan sejumlah besar data ke dalam pangkalan data boleh menjadi proses yang memakan masa. Secara tradisinya, satu pendekatan melibatkan pelaksanaan satu siri arahan sisipan individu, yang boleh menjadi tidak cekap dan intensif sumber.

Untuk mengoptimumkan proses ini, anda boleh memasukkan berbilang baris sekaligus menggunakan satu pertanyaan. Dalam CodeIgniter, ini boleh dicapai menggunakan kelas Model.

Membina Pertanyaan

Kunci untuk memasukkan berbilang baris dengan satu pertanyaan terletak pada memasang pernyataan SQL dengan betul . Daripada menambahkan setiap nilai pada rentetan panjang, anda boleh menggunakan tugasan tatasusunan dan fungsi meletup.

$data = [
    ['text' => 'foo', 'category_id' => 1],
    ['text' => 'bar', 'category_id' => 2],
    // ...
];

$sql = [];

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

$sql = implode(',', $sql);

Melaksanakan Pertanyaan

Setelah penyataan SQL dibina , anda boleh melaksanakannya menggunakan pertanyaan kelas Model kaedah:

$this->db->query('INSERT INTO table (text, category_id) VALUES ' . $sql);

Faedah Sisipan Pukal

Menggunakan teknik sisipan pukal menawarkan beberapa kelebihan:

  • Masa Pelaksanaan Dikurangkan : Menggabungkan berbilang sisipan ke dalam satu pertanyaan dengan ketara mengurangkan overhed pangkalan data dan masa pelaksanaan.
  • Penggunaan Memori yang Dipertingkat: Mengelakkan mencipta rentetan bersambung panjang, yang boleh menggunakan memori yang berlebihan.
  • Kod Ringkas: Menyatukan berbilang sisipan penyata menjadi satu pertanyaan yang lebih terurus.

Atas ialah kandungan terperinci Bagaimanakah Kelas Model CodeIgniter Boleh Mengoptimumkan Sisipan Pangkalan Data Pukal?. 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