>백엔드 개발 >PHP 튜토리얼 >바인드 변수 수가 결과 세트 열과 일치하지 않을 때 `mysqli_stmt::bind_result()`에서 오류가 발생하는 이유는 무엇입니까?

바인드 변수 수가 결과 세트 열과 일치하지 않을 때 `mysqli_stmt::bind_result()`에서 오류가 발생하는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-11 09:01:09198검색

Why Does `mysqli_stmt::bind_result()` Throw an Error When the Number of Bind Variables Doesn't Match the Result Set Columns?

mysqli_stmt::bind_result()의 바인딩 변수 불일치

PHP에서 mysqli_stmt::bind_result()를 사용하여 준비된 명령문을 실행할 때, 바인드 변수의 수는 결과 세트의 필드 수와 일치해야 합니다. 일치하지 않으면 "mysqli_stmt::bind_result(): 바인드 변수 수가 준비된 문의 필드 수와 일치하지 않습니다"라는 오류가 발생합니다.

이 문제를 해결하려면 숫자가 일치하는지 확인하세요. Bind_result()의 바인드 변수 수는 쿼리에서 반환된 열 수에 맞춰 정렬됩니다. 다음 PHP 코드를 고려하십시오.

$stmt = $mysqli->prepare("SELECT username, password FROM users WHERE username = ?");
$username = $_POST['name'];
$stmt->bind_param('s', $username);
$stmt->execute();
$stmt->bind_result($password, $username); // Incorrect number of bind variables
$stmt->fetch();

이 예에서 준비된 문은 사용자 이름과 비밀번호라는 두 개의 열을 검색합니다. 그러나 바인딩_result()에는 하나의 바인드 변수인 $username만 지정됩니다. 이 문제를 해결하려면 $password에 대한 두 번째 바인드 변수를 추가하세요.

$stmt->bind_result($username, $password); // Correct number of bind variables

SELECT 문의 구문은 다음과 같습니다. SELECT field1, field2, ... fieldN FROM table_name WHERE .... 각 필드는 구분되어야 합니다. AND 조건이 아닌 쉼표로 입력하세요.

위 내용은 바인드 변수 수가 결과 세트 열과 일치하지 않을 때 `mysqli_stmt::bind_result()`에서 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.