Heim >Backend-Entwicklung >PHP-Tutorial >Warum erhalte ich in meinem PDO-Code den Fehler „Aufruf einer Mitgliedsfunktion Prepare() für ein Nicht-Objekt'?

Warum erhalte ich in meinem PDO-Code den Fehler „Aufruf einer Mitgliedsfunktion Prepare() für ein Nicht-Objekt'?

Susan Sarandon
Susan SarandonOriginal
2024-11-14 16:04:02874Durchsuche

Why Am I Getting a

pdo – Aufruf einer Mitgliedsfunktion „prepare()“ für ein Nicht-Objekt

Beim Versuch, Benutzereingaben mithilfe von PDO zu validieren, tritt ein Fehler auf, der darauf hinweist, dass die Vorbereitung ()-Methode wird für ein Nicht-Objekt aufgerufen. Dieser Fehler tritt speziell in Zeile 42 des bereitgestellten Codes auf.

Um dieses Problem zu beheben, überprüfen Sie den Code, um sicherzustellen, dass das $pdo-Objekt ordnungsgemäß definiert und innerhalb der Funktion repetirDados() zugänglich ist. Der Fehler deutet darauf hin, dass $pdo im aktuellen Bereich nicht verfügbar ist.

Bestätigen Sie, ob $pdo als Argument an die Funktion übergeben wird oder ob es als globale Variable definiert ist. Wenn keines dieser Szenarios zutrifft, können Sie $pdo im globalen Namespace definieren und das globale Schlüsselwort innerhalb der Funktion verwenden, um darauf zuzugreifen:

global $pdo;

Alternativ können Sie $pdo als Argument an übergeben repetirDados()-Funktion, um sicherzustellen, dass sie innerhalb des Funktionsumfangs verfügbar ist.

Entspricht mysql_num_rows

Das Äquivalent von mysql_num_rows in PDO ist rowCount(). Es gibt die Anzahl der Zeilen zurück, die von der letzten Abfrageausführung betroffen waren. In diesem Fall können Sie rowCount() verwenden, um zu überprüfen, ob von der Abfrage Zeilen zurückgegeben wurden:

if ($stmt->rowCount() == 0) {
    // No results found
} else {
    // Results found
}

Das obige ist der detaillierte Inhalt vonWarum erhalte ich in meinem PDO-Code den Fehler „Aufruf einer Mitgliedsfunktion Prepare() für ein Nicht-Objekt'?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn