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

Barbara Streisand
Lepaskan: 2024-10-31 04:13:30
asal
281 orang telah melayarinya

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>
Salin selepas log masuk
<code class="php">// Model
public function delete($user_id)
{
    $this->db->delete('user_table', ['user_id' => $user_id]);
    return $this->db->affected_rows();
}</code>
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!