PHP 코드에서 prepare() 메서드에 액세스하려고 한다는 오류 메시지가 표시됩니다. 존재하지 않는 개체의 것입니다. 이 오류의 원인을 식별하기 위해 제공된 코드를 살펴보겠습니다.
$DBH = new mysqli("host", "test", "123456", "dbname"); function selectInfo($limit, $offset) { $stmt = $DBH->prepare("SELECT * FROM information LIMIT ?,?"); $stmt->bind_param("ii", $limit, $offset); $stmt->execute(); } selectInfo();
오류는 $DBH 변수의 범위에서 발생합니다. selectInfo() 함수 내에서 범위를 지정하지 않고 $DBH에 액세스하려고 합니다. $DBH는 함수 내에 정의되어 있지 않으므로 직접 액세스할 수 없습니다.
이 문제를 해결하려면 다음과 같은 몇 가지 옵션이 있습니다.
1. 글로벌 키워드 사용:
function selectInfo($limit, $offset) { global $DBH; $stmt = $DBH->prepare("SELECT * FROM information LIMIT ?,?"); $stmt->bind_param("ii", $limit, $offset); $stmt->execute(); }
2. $DBH를 함수 매개변수로 전달합니다:
function selectInfo($DBH, $limit, $offset) { $stmt = $DBH->prepare("SELECT * FROM information LIMIT ?,?"); $stmt->bind_param("ii", $limit, $offset); $stmt->execute(); }
3. $DBH를 검색하는 함수 만들기:
function getDBH() { static $DBH = null; if (is_null($DBH)) { $DBH = new mysqli("host", "test", "123456", "dbname"); } return $DBH; } function selectInfo($limit, $offset) { $DBH = getDBH(); $stmt = $DBH->prepare("SELECT * FROM information LIMIT ?,?"); $stmt->bind_param("ii", $limit, $offset); $stmt->execute(); }
이러한 옵션 중 하나를 구현하면 selectInfo() 함수 내에서 $DBH에 대한 올바른 범위를 설정하여 필요한 데이터베이스에 액세스할 수 있습니다. 연결합니다.
위 내용은 내 PHP 코드에서 \'비객체에 대한 prepare() 멤버 함수 호출\' 오류가 발생하는 이유는 무엇이며 어떻게 해결할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!