MySQL 데이터베이스 작업에 PHP를 사용할 때 "PHP 치명적인 오류: 정의되지 않은 메서드 mysqli::stmt_init() 호출" 오류가 자주 발생합니다. 이 오류는 일반적으로 PHP가 MySQL 확장 라이브러리 또는 MySQL 확장 라이브러리를 올바르게 로드하지 않아서 발생합니다. . 버전 비호환으로 인해 발생합니다. 이번 글에서는 이 문제를 해결하는 방법을 설명하겠습니다.
1단계: PHP가 MySQL 확장 라이브러리를 올바르게 로드하는지 확인하세요.
PHP에서는 phpinfo() 함수를 통해 현재 PHP 구성 정보를 볼 수 있습니다. 터미널을 열고 다음 명령을 입력하면 현재 PHP 구성 정보를 볼 수 있습니다.
php -r "phpinfo();"
이 명령을 실행하면 PHP 구성 정보가 출력됩니다. MySQL 확장 라이브러리가 로드되었는지 확인해야 합니다.
Ctrl+F를 통해 mysqli를 검색할 수 있습니다. 찾을 수 없다면 MySQL 확장 라이브러리가 로드되지 않았다는 의미이므로 먼저 MySQL 확장 라이브러리를 설치해야 합니다.
2단계: MySQL 확장 라이브러리 설치
실제 상황에 따라 다음 두 가지 방법으로 MySQL 확장 라이브러리를 설치할 수 있습니다.
sudo apt-get update sudo apt-get install php-mysql
sudo yum update sudo yum install php-mysql
위 명령을 실행할 수 없는 경우 확장을 수동으로 컴파일하고 설치하도록 선택할 수 있습니다. Ubuntu 시스템을 예로 들어보겠습니다.
sudo apt-get update sudo apt-get install php7.2-dev libmysqlclient-dev sudo pecl channel-update pecl.php.net sudo pecl install mysqlnd_ms
위 명령의 php7.2-dev를 현재 사용되는 PHP 버전으로 수정해야 합니다. libmysqlclient-dev가 설치되어 있지 않으면 설치되지 않습니다. 성공적으로 컴파일되었습니다.
설치가 완료된 후 php.ini에 다음 구성 정보를 추가해야 합니다.
extension=mysqlnd_ms.so
3단계: Apache 서비스 다시 시작
MySQL 확장 라이브러리를 설치한 후 Apache 서비스를 다시 시작해야 이를 만들 수 있습니다. 적용:
sudo /etc/init.d/apache2 restart
sudo systemctl restart httpd
위의 세 단계를 완료한 후 프로그램을 다시 실행하면 MySQL 데이터베이스에 정상적으로 접속하여 작동할 수 있습니다.
요약:
MySQL 데이터베이스 작업에 PHP를 사용할 때 "PHP 치명적인 오류: 정의되지 않은 메서드 mysqli::stmt_init() 호출" 오류가 발생하기 쉽습니다. 이 오류는 일반적으로 PHP가 MySQL 확장을 로드하지 않아서 발생합니다. 또는 MySQL 확장 라이브러리 버전이 호환되지 않습니다. 이 문제를 해결하려면 phpinfo() 함수에서 반환된 정보를 확인하여 MySQL 확장 라이브러리가 올바르게 로드되었는지 확인할 수 있습니다. 올바르게 로드되지 않은 경우 명령줄을 통해 또는 수동으로 MySQL 확장 라이브러리를 설치해야 합니다. 이를 컴파일하고 설치합니다. 설치가 완료된 후 적용하려면 Apache 서비스를 다시 시작해야 합니다.
위 내용은 PHP 치명적인 오류에 대한 해결 방법: 정의되지 않은 메서드 mysqli::stmt_init() 호출의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!