MySQLi: "정의되지 않은 메서드 호출 mysqli_stmt::get_result() 오류 해결
PHP에서 MySQLi로 MySQL 쿼리를 실행할 때, "정의되지 않은 메소드 mysqli_stmt::get_result() 호출" 오류가 발생할 수 있습니다. 이 문제는 일반적으로 MySQL 네이티브 드라이버(mysqlnd)가 설치되지 않은 경우에 발생합니다.
다음 코드 조각을 고려하세요.
$stmt = $conn->mysqli->prepare($query); $stmt->bind_param('sss', $_POST['EmailID'], $_POST['SLA'], $_POST['Password']); $stmt->execute(); $result = $stmt->get_result();
이 예에서 $result = $stmt- >get_result(); 행에서 "정의되지 않은 메소드 mysqli_stmt::get_result() 호출" 오류가 발생합니다. get_result() 메서드에는 mysqlnd 드라이버가 필요하며 이는 웹 호스팅 환경에 항상 설치되지는 않습니다.
이 문제를 해결하려면 phpinfo()를 확인하여 mysqlnd 드라이버가 활성화되어 있는지 확인하세요. 출력하거나 다음과 같은 명령을 사용합니다.
php -i | grep mysqlnd
mysqlnd 드라이버가 설치되지 않은 경우 다음을 따르세요. 단계:
Debian 기반 시스템의 경우:
sudo apt-get install php-mysqlnd
Red Hat 기반 시스템의 경우:
sudo yum install php-mysqlnd
Mac OS X의 경우 Homebrew:
brew install php-mysqlnd
Windows 시스템의 경우:
mysqlnd 드라이버를 활성화하여 최신 버전의 PHP를 설치합니다.
설치 후 mysqlnd 드라이버를 사용하는 경우 변경 사항을 로드하려면 웹 서버를 다시 시작해야 합니다. 드라이버가 설치되고 활성화되면 get_result() 메서드가 제대로 작동합니다.
또는 mysqlnd를 설치할 수 없는 경우, 바인딩_result() 및 fetch() 메서드를 사용하여 쿼리 결과를 검색할 수 있습니다. . 이러한 방법은 get_result()보다 효율성이 떨어지지만 mysqlnd 드라이버가 필요하지 않습니다.
위 내용은 내 PHP MySQLi 코드에서 '정의되지 않은 메서드 mysqli_stmt::get_result() 호출' 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!