준비된 문 삽입에서 바인드 변수 수가 일치하지 않습니다.
MySQL 준비된 문을 사용하여 INSERT 문을 실행할 때 사용자에게 다음 오류가 발생할 수 있습니다. " 바인드 변수 수가 준비된 문의 필드 수와 일치하지 않습니다."
이 문제는 바인딩_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 문에는 두 개의 자리 표시자(?)가 있습니다. 하나는 사용자용이고 다른 하나는 패스용입니다. 그러나 바인딩_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; }
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3