> 백엔드 개발 > PHP 튜토리얼 > 내 PHP MySQLi 코드에서 '정의되지 않은 메서드 mysqli_stmt::get_result() 호출' 오류가 발생하는 이유는 무엇입니까?

내 PHP MySQLi 코드에서 '정의되지 않은 메서드 mysqli_stmt::get_result() 호출' 오류가 발생하는 이유는 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-12-26 21:11:10
원래의
574명이 탐색했습니다.

Why Does My PHP MySQLi Code Throw a

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿