Rumah > pangkalan data > tutorial mysql > 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
Lepaskan: 2024-11-18 02:19:02
asal
359 orang telah melayarinya

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
}
Salin selepas log masuk

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
Salin selepas log masuk

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!");
}
Salin selepas log masuk

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!

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