Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimanakah saya boleh mengesan kejayaan pertanyaan Cipta, Kemas Kini atau Padam dalam CodeIgniter dengan pasti?

Bagaimanakah saya boleh mengesan kejayaan pertanyaan Cipta, Kemas Kini atau Padam dalam CodeIgniter dengan pasti?

Barbara Streisand
Barbara Streisandasal
2024-10-31 04:13:30279semak imbas

How can I reliably detect the success of a Create, Update, or Delete query in CodeIgniter?

Mengesan Kejayaan Buat, Kemas Kini atau Padam Pertanyaan dalam CodeIgniter

Apabila melaksanakan operasi pangkalan data dalam CodeIgniter, adalah penting untuk mengesahkannya kejayaan. Kegagalan berbuat demikian boleh menyebabkan ketidakkonsistenan data atau hasil yang salah ditunjukkan kepada pengguna.

Pendekatan Salah:

Kaedah pengawal yang disediakan menganggap bahawa sebarang pulangan bukan sifar nilai daripada kaedah model kemas kini() menunjukkan kejayaan. Walau bagaimanapun, ini bukan pendekatan yang boleh dipercayai kerana model mungkin mengembalikan nilai bukan sifar walaupun apabila pertanyaan gagal mengemas kini mana-mana baris.

Pendekatan Betul:

Untuk betul mengesan kejayaan operasi pangkalan data, adalah disyorkan untuk menggunakan langkah berikut:

Pengawal:

  • Terima data input dengan selamat melalui POST, bukan melalui URL.
  • Gunakan kaedah affected_rows() kelas pangkalan data CodeIgniter untuk mengesahkan bilangan baris yang terjejas selepas melaksanakan pertanyaan.
  • Ubah hala pengguna dan paparkan mesej kejayaan atau ralat berdasarkan bilangan baris yang terjejas.

Model:

  • Kendalikan pertanyaan pangkalan data dan semakan ralat.
  • Gunakan kaedah kemas kini() dalam kelas pangkalan data CodeIgniter untuk melaksanakan pertanyaan.
  • Kembalikan bilangan baris yang terjejas, membenarkan pengawal menentukan hasil operasi.

Contoh:

<code class="php">// Controller
public function delete($user_id)
{
    if ($this->input->server('REQUEST_METHOD') == 'POST') {
        $result = $this->Crm_user_model->delete($user_id);
        if ($result === false) {
            add_flash_message('alert', 'Failed to delete user');
        } else if ($result == 0) {
            add_flash_message('info', 'User not found or already deleted');
        } else {
            add_flash_message('info', 'User deleted successfully');
        }
    }
}</code>
<code class="php">// Model
public function delete($user_id)
{
    $this->db->delete('user_table', ['user_id' => $user_id]);
    return $this->db->affected_rows();
}</code>

Pertimbangan Tambahan:

  • Seperti yang dinyatakan dalam penyelesaian yang disediakan, adalah dinasihatkan untuk memasukkan pemeriksaan keselamatan dalam kedua-dua pengawal dan model untuk mengelakkan tindakan yang tidak dibenarkan akses atau input data berniat jahat.
  • Adalah berfaedah untuk menyimpan sejarah perubahan dalam sistem anda untuk menjejaki perubahan yang dibuat pada rekod pangkalan data.
  • Untuk operasi pangkalan data yang kompleks, pertimbangkan untuk menggunakan corak ActiveRecord CodeIgniter, yang menyediakan pendekatan yang lebih berstruktur untuk manipulasi pangkalan data.

Atas ialah kandungan terperinci Bagaimanakah saya boleh mengesan kejayaan pertanyaan Cipta, Kemas Kini atau Padam dalam CodeIgniter dengan pasti?. 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