>  기사  >  백엔드 개발  >  INSERT 쿼리에서 \"바인드 변수 수가 필드 수와 일치하지 않습니다\" 오류가 발생하는 이유는 무엇입니까?

INSERT 쿼리에서 \"바인드 변수 수가 필드 수와 일치하지 않습니다\" 오류가 발생하는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-10-28 09:41:29966검색

Why Am I Getting a

INSERT 쿼리로 인해 문제 발생: 바인드 변수 수가 준비된 문과 호환되지 않음

PHP 코드에서 오류 메시지는 준비된 명령문의 바인드 변수 및 필드 수입니다. 특히 경고 내용은 다음과 같습니다.

"경고: mysqli_stmt::bind_result(): 바인드 변수 수가 준비된 문의 필드 수와 일치하지 않습니다."

이 오류는 다음 코드에서 발생합니다. :

if($stmt = $conn -> prepare("INSERT INTO login(user, pass) VALUES(?, ?)")) {

  /* Bind parameters s - string, b - blob, i - int, etc */
  $stmt -> bind_param("ss", $user, $pw);

  /* Execute it */
  $stmt -> execute();

  /* Bind results */
  $stmt -> bind_result($user, $pw);

  /* Close statement */
  $stmt -> close();
  $userId = $conn->insert_id;
}

문제 이해

이 오류는 결과 변수($user 및 $pw)를 결과 변수를 반환하지 않는 문에 바인딩하려고 시도하여 발생합니다. 결과. 이 경우 INSERT 쿼리에는 SELECT 절이나 값을 반환하는 저장 프로시저가 없습니다. 따라서 결과 변수 바인딩은 필요하지 않습니다.

문제 해결

문제를 해결하려면 결과 변수를 바인딩하는 줄을 제거하세요.

$stmt -> bind_result($user, $pw);

이 줄을 제거하면 바인드 변수 수(0)와 준비된 문의 필드 수(또한 0) 간의 불일치가 제거됩니다. 이렇게 하면 오류가 해결되고 코드가 성공적으로 실행될 수 있습니다.

위 내용은 INSERT 쿼리에서 \"바인드 변수 수가 필드 수와 일치하지 않습니다\" 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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