Heim >Datenbank >MySQL-Tutorial >Wie vermeide ich den Fehler „Versuch, auf den Array-Offset für einen Wert vom Typ bool zuzugreifen' in PHP-Datenbankabfragen?
Umgang mit dem Fehler „Versuch, auf den Array-Offset für einen Wert vom Typ Bool zuzugreifen“ bei der Prüfung auf Datenbankexistenz
Beim Prüfversuch Wenn ein Datensatz in einer Datenbank vorhanden ist, kann bei Entwicklern der Fehler „Es wird versucht, auf den Array-Offset für einen Wert vom Typ Bool zuzugreifen“ auftreten. Dies tritt normalerweise auf, wenn die Datenbankabfrage keine Ergebnisse zurückgibt, was dazu führt, dass der boolesche Wert „false“ zurückgegeben wird.
Um diesen Fehler zu beheben, muss überprüft werden, ob Datensätze aus der Datenbank abgerufen wurden. Dies kann erreicht werden, indem der Datenbankabrufvorgang in eine bedingte Anweisung gekapselt wird, die seine Existenz prüft.
$emailRes = $query->fetch(PDO::FETCH_ASSOC); if ($emailRes) { // Use $emailRes }
Alternativ können Sie einen Standardwert zuweisen, wenn die Datenbank nichts zurückgegeben hat.
$emailRes = $query->fetch(PDO::FETCH_ASSOC); $email = $emailRes['Email'] ?? ''; // Default: empty string
Um mithilfe von PDO korrekt zu prüfen, ob eine Datenbank vorhanden ist, wird die Verwendung des folgenden Ansatzes empfohlen:
$query = $pdo->prepare("SELECT COUNT(*) FROM Users WHERE Username =:Username"); $query->execute([':Username' => $name]); if ($query->fetchColumn()) { throw new \Exception("Username is already in use!"); } $query = $pdo->prepare("SELECT COUNT(*) FROM Users WHERE Email =:Email"); $query->execute([':Email' => $email]); if ($query->fetchColumn()) { throw new \Exception("Email is already in use!"); }
Diese Methode ruft die Anzahl übereinstimmender Zeilen ab und wertet sie als booleschen Wert aus, sodass kein weiterer Vergleich erforderlich ist PHP.
Um zu überprüfen, ob in einer einzelnen Abfrage entweder der Benutzername oder die E-Mail-Adresse vorhanden ist, kann Folgendes verwendet werden:
$query = $pdo->prepare("SELECT COUNT(*) FROM Users WHERE Username =:Username OR Email =:Email"); $query->execute([':Username' => $name, ':Email' => $email]); if ($query->fetchColumn()) { throw new \Exception("Username or email is already in use!"); }
Das obige ist der detaillierte Inhalt vonWie vermeide ich den Fehler „Versuch, auf den Array-Offset für einen Wert vom Typ bool zuzugreifen' in PHP-Datenbankabfragen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!