>  기사  >  백엔드 개발  >  MySQLi 준비된 명령문에서 \"바인드 변수 수 불일치\" 오류가 발생하는 이유는 무엇입니까?

MySQLi 준비된 명령문에서 \"바인드 변수 수 불일치\" 오류가 발생하는 이유는 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-10-27 19:31:30645검색

Why Am I Getting

Prepared 문 삽입 시 바인드 변수 수가 일치하지 않습니다

MySQLi 준비된 문을 사용하여 INSERT 문을 실행할 때 사용자에게 다음 오류가 발생할 수 있습니다. 바인드 변수 수가 준비된 문의 필드 수와 일치하지 않습니다."

이 문제는 bind_param() 메서드에 제공된 바인드 변수 수가 INSERT 쿼리의 자리 표시자 수와 일치하지 않을 때 발생합니다. . 예를 들어 아래 코드 조각을 살펴보세요.

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;
}

이 코드에서 INSERT 문에는 두 개의 자리 표시자(?)가 있습니다. 하나는 사용자용이고 다른 하나는 패스용입니다. 그러나 bin_param() 메서드는 두 개의 변수($user, $pw)를 자리 표시자에 바인딩합니다. 이로 인해 불일치 오류가 발생합니다.

INSERT 문이 결과를 반환하지 않으므로 해결 방법은 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();

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

위 내용은 MySQLi 준비된 명령문에서 \"바인드 변수 수 불일치\" 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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