집 >데이터 베이스 >MySQL 튜토리얼 >mysqli_stmt::bind_param()이 \'유형 정의 문자열 불일치\' 오류를 발생시키는 이유는 무엇입니까?
mysqli_stmt::bind_param(): 유형 정의 문자열 불일치
mysqli_stmt::bind_param()을 사용하여 준비된 명령문을 실행할 때 다음이 중요합니다. 유형 정의 문자열의 요소 수는 바인드 변수 수와 일치합니다. 이러한 불일치로 인해 "유형 정의 문자열의 요소 수가 바인드 변수의 수와 일치하지 않습니다."라는 오류 메시지가 나타나는 경우가 많습니다.
문제 설명
원래 쿼리 준비된 명령문을 사용하여 데이터베이스에 65개의 변수를 주입하는 작업이 포함됩니다. 다만, 변수 개수와 타입 정의 문자열의 "s" 문자 개수에 차이가 있습니다.
해상도
유형 정의 문자열("s,s...")은 쿼리의 바인드 변수 수와 동일해야 합니다. 이 경우 바인드 변수가 65개이므로 유형 정의 문자열에는 "s" 문자 65개가 포함되어야 합니다.
예
// Prepare query $query3 = '... (65 bind variables here) ...'; // Prepare statement $stmt = $dbConnection->prepare($query3); // Bind parameters $stmt->bind_param( "ssssssssssssssssssssssssssssssssssssssssssssssssssssssssss", // 65 variables listed here ); // Execute query $stmt->execute();
이 예에서는 유형 정의 문자열에는 65개의 "s" 문자가 포함되어 있으며, 이는 쿼리.
일반적인 함정
추가 고려 사항
위 내용은 mysqli_stmt::bind_param()이 \'유형 정의 문자열 불일치\' 오류를 발생시키는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!