Home > Database > Mysql Tutorial > Why Does `mysqli_stmt::bind_result()` Throw a Bind Variable Mismatch Error?

Why Does `mysqli_stmt::bind_result()` Throw a Bind Variable Mismatch Error?

Patricia Arquette
Release: 2024-12-10 21:46:14
Original
666 people have browsed it

Why Does `mysqli_stmt::bind_result()` Throw a Bind Variable Mismatch Error?

Bind Variable Mismatch in PHP's mysqli_stmt::bind_result()

When attempting to log in using a PHP login form with a prepared statement, you encounter the error:

mysqli_stmt::bind_result(): Number of bind variables doesn't match number of fields in prepared statement
Copy after login

Diagnosis:

This error occurs when the number of bind variables specified in bind_param() does not match the number of fields returned by the prepared statement.

Solution:

In your code:

$stmt->prepare("SELECT username AND password FROM users WHERE username = ?");
Copy after login

The prepared statement retrieves two fields, username and password, but your subsequent bind_param() and bind_result() calls specify only one bind variable, $username.

To resolve this, you need to correctly specify multiple bind variables and fields:

$mysqli->prepare("SELECT username, password FROM users WHERE username = ?");
$username = $_POST['name'];
$stmt->bind_param('s', $username);
$stmt->execute();
$stmt->bind_result($username, $password);
Copy after login

The above is the detailed content of Why Does `mysqli_stmt::bind_result()` Throw a Bind Variable Mismatch Error?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template