Rumah  >  Artikel  >  pangkalan data  >  Mengapa Saya Mendapat Ralat \"Cuba mengakses tatasusunan mengimbangi nilai jenis bool\" dalam Kod PHP Saya?

Mengapa Saya Mendapat Ralat \"Cuba mengakses tatasusunan mengimbangi nilai jenis bool\" dalam Kod PHP Saya?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-11-18 02:19:02304semak imbas

Why Am I Getting a

Tidak Dapat Mengakses Array Offset pada Nilai Boolean dalam PHP

Menghadapi ralat "Mencuba untuk mengakses array ofset pada nilai jenis bool" dalam PHP menandakan bahawa kod cuba untuk mendapatkan semula elemen tatasusunan daripada nilai yang bukan tatasusunan, dalam kes ini, boolean.

Dalam kod yang disediakan, anda sedang menyoal pangkalan data untuk pengguna berdasarkan nama pengguna dan e-mel mereka. Setelah menerima keputusan, anda menyemak sama ada nama pengguna atau e-mel sudah wujud dengan membandingkan respons pangkalan data dengan input daripada borang pendaftaran.

Walau bagaimanapun, ralat berlaku apabila pertanyaan pangkalan data tidak mengembalikan rekod yang sepadan dengan kriteria. Akibatnya, $emailRes (dan $nameRes) menjadi boolean (false) dan bukannya tatasusunan bersekutu. Akibatnya, mengakses $emailRes['Email'] menimbulkan ralat kerana anda tidak boleh mengakses array ofset pada nilai boolean.

Menyelesaikan Isu

Semak Keputusan Pangkalan Data:

Penyelesaian paling mudah adalah dengan terlebih dahulu menyemak sama ada pertanyaan pangkalan data mengembalikan sebarang hasil sebelum cuba mengakses tatasusunan $emailRes.

$emailRes = $query->fetch(PDO::FETCH_ASSOC);
if ($emailRes) {
    // Proceed to use $emailRes
}

Sediakan Nilai Lalai:

Jika anda tidak peduli sama ada pangkalan data mengembalikan apa-apa, anda boleh memberikan nilai lalai.

$emailRes = $query->fetch(PDO::FETCH_ASSOC);
$email = $emailRes['Email'] ?? ''; // Default: empty string

Pendekatan Alternatif:

A amalan yang lebih baik ialah menggunakan kaedah rowCount() atau fetchColumn() PDO untuk menyemak kewujudan baris dalam pangkalan data, mengelakkan kemungkinan hasil boolean.

$query = $pdo->prepare("SELECT COUNT(*) FROM Users WHERE Username = :Username");
$query->execute([':Username' => $name]);
if ($query->fetchColumn()) {
    throw new \Exception("Username is already in use!");
}

Dengan menyemak kiraan baris dan bukannya mengambil data , anda menghapuskan kemungkinan menerima hasil boolean, memastikan anda tidak akan menemui "array offset on boolean" ralat.

Atas ialah kandungan terperinci Mengapa Saya Mendapat Ralat \"Cuba mengakses tatasusunan mengimbangi nilai jenis bool\" dalam Kod PHP Saya?. 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