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?

Wie vermeide ich den Fehler „Versuch, auf den Array-Offset für einen Wert vom Typ bool zuzugreifen' in PHP-Datenbankabfragen?

Patricia Arquette
Patricia ArquetteOriginal
2024-11-19 03:02:02653Durchsuche

How to Avoid the

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!

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