Rumah > pembangunan bahagian belakang > tutorial php > Mengapa Pernyataan Disediakan MySQLi Saya Melemparkan Ralat 'Bilangan pembolehubah ikatan tidak sepadan dengan bilangan medan'?

Mengapa Pernyataan Disediakan MySQLi Saya Melemparkan Ralat 'Bilangan pembolehubah ikatan tidak sepadan dengan bilangan medan'?

Patricia Arquette
Lepaskan: 2024-12-15 21:30:26
asal
241 orang telah melayarinya

Why Does My MySQLi Prepared Statement Throw a

Pembolehubah Bind Tidak Padan dalam Penyata Disediakan MySQLi

Apabila cuba melaksanakan borang log masuk menggunakan pernyataan yang disediakan dalam PHP, sesetengah pembangun menghadapi masalah yang mengecewakan ralat: "mysqli_stmt::bind_result(): Bilangan pembolehubah ikatan tidak sepadan dengan bilangan medan dalam pernyataan yang disediakan."

Ralat ini timbul apabila pertanyaan SQL dan fungsi bind_result() mengandungi ketidakpadanan dalam bilangan medan yang dipilih dan diberikan kepada pembolehubah. Mari kita periksa cara menangani isu ini berdasarkan kod yang disediakan.

Dalam kod yang disediakan:

$stmt = $mysqli->prepare("SELECT username AND password FROM users WHERE username = ?");
$stmt->bind_param('s', $username);
$stmt->execute();
$stmt->bind_result($password, $username);
Salin selepas log masuk

Isunya terletak pada pertanyaan SQL. Kata kunci "DAN" digunakan bukannya koma apabila memilih berbilang medan. Sintaks yang betul untuk memilih berbilang medan ialah memisahkannya dengan koma:

$stmt = $mysqli->prepare("SELECT username, password FROM users WHERE username = ?");
Salin selepas log masuk

Selain itu, fungsi bind_result() hendaklah sepadan dengan bilangan medan yang dipilih. Dalam kes ini, dua medan dipilih, jadi fungsi bind_result() harus mempunyai dua pembolehubah:

$stmt->bind_result($username, $password);
Salin selepas log masuk

Dengan membetulkan sintaks pilih dan menjajarkan fungsi bind_result() dengan bilangan medan yang dipilih, isu ini pembolehubah ikatan yang tidak sepadan akan diselesaikan, membolehkan borang log masuk berfungsi dengan betul.

Atas ialah kandungan terperinci Mengapa Pernyataan Disediakan MySQLi Saya Melemparkan Ralat 'Bilangan pembolehubah ikatan tidak sepadan dengan bilangan medan'?. 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