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 중국어 웹사이트의 기타 관련 기사를 참조하세요!