>백엔드 개발 >PHP 튜토리얼 >내 PHP 코드에서 \'비객체에 대한 prepare() 멤버 함수 호출\' 오류가 발생하는 이유는 무엇이며 어떻게 해결할 수 있나요?

내 PHP 코드에서 \'비객체에 대한 prepare() 멤버 함수 호출\' 오류가 발생하는 이유는 무엇이며 어떻게 해결할 수 있나요?

Barbara Streisand
Barbara Streisand원래의
2024-11-24 05:45:11743검색

Why does my PHP code throw a

비객체에서 prepare() 멤버 함수 호출

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

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.