mysqli::query(): Objek mysqli Telah Ditutup / Tidak Dapat Mengambil Ralat mysqli
Dalam PHP, mesej ralat yang menunjukkan "Tidak dapat mengambil mysqli" biasanya berlaku apabila cuba mengakses sambungan pangkalan data tertutup. Ini biasanya timbul dalam skrip pengaturcaraan berorientasikan objek (OOP) di mana sambungan mysqli ditutup lebih awal.
Senario Ralat
Kod yang disediakan dalam class_EventCalendar.php membuang ralat disebabkan oleh isu berikut:
-
Pemusnah Kelakuan: Kaedah __destruct() menutup objek $DBConnect apabila kejadian EventCalendar dimusnahkan. Ini bermakna bahawa sebarang pertanyaan seterusnya yang cuba dicuba selepas pemusnahan akan gagal.
-
Pelaksanaan Pertanyaan: Dalam kaedah addEvent(), objek $DBConnect digunakan untuk melaksanakan pertanyaan SQL. Walau bagaimanapun, sejak pemusnah menutup sambungan, objek $DBConnect tidak lagi boleh digunakan.
-
Parameter DBConnect: Pastikan parameter @new mysqli() betul untuk tetapan pelayan pangkalan data anda. Dalam kod contoh, parameter ini telah diubah suai daripada nilai asalnya.
Penyelesaian
Untuk menyelesaikan isu ini, pertimbangkan perkara berikut:
-
Semak Logik Pemusnah: Ubah suai kaedah __destruct() untuk menutup sahaja Objek $DBConnect jika tiada pertanyaan yang tinggal untuk dilaksanakan. Ini akan menghalang penutupan pramatang sambungan.
-
Pengendalian Ralat Sambungan: Kendalikan ralat sambungan dengan anggun dalam fail sambungan pangkalan data menggunakan blok cuba-tangkap atau teknik pengendalian ralat lain.
-
Versi PHP: Ralat "objek mysqli sudah ditutup" juga boleh berlaku dalam PHP 8 kerana perubahan dalam pengendalian objek mysqli tertutup. Pastikan versi PHP anda dikemas kini.
Petua Penyelesaian Masalah Tambahan
- Gunakan mysqli::error untuk menyemak mesej ralat dikaitkan dengan pertanyaan yang gagal.
- Pastikan bahawa permulaan $_SESSION dipanggil sebelum membuat objek sambungan mysqli.
- Semak skrip PHP untuk sebarang keadaan lain di mana sambungan mysqli ditutup lebih awal.
Atas ialah kandungan terperinci Mengapa Saya Mendapat Ralat 'Objek mysqli Sudah Ditutup' dalam Kod PHP Saya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!