„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Warum gibt „mysqli_query()“ „Warnung: mysqli_query() erwartet, dass Parameter 1 MySQLi ist, null gegeben“ zurück?

Warum gibt „mysqli_query()“ „Warnung: mysqli_query() erwartet, dass Parameter 1 MySQLi ist, null gegeben“ zurück?

Veröffentlicht am 22.12.2024
Durchsuche:214

Why Does `mysqli_query()` Return

Verstehen von „Warnung: mysqli_query() erwartet, dass Parameter 1 MySQLi ist, null angegeben in“ Fehler

Bei Ihrem Versuch, eine benutzerdefinierte zu erstellen CMS, Sie haben die folgende Fehlermeldung erhalten:

"Warnung: mysqli_query() erwartet Parameter 1 MySQLi, null angegeben in"

Ursache des Fehlers

Dieser Fehler weist darauf hin, dass die Funktion mysqli_query(), die SQL-Abfragen ausführt, als erstes ein MySQLi-Objekt erwartet Parameter. Allerdings übergeben Sie in Ihrer getPosts()-Funktion einen Nullwert anstelle eines MySQLi-Objekts.

Lösung

Die Lösung für dieses Problem besteht darin, sicherzustellen, dass die Das $con MySQLi-Objekt liegt im Bereich der getPosts()-Funktion. In Ihrem Code ist $con im globalen Bereich definiert, aber innerhalb der Funktion ist es nicht zugänglich.

Übergabe des MySQLi-Objekts als Abhängigkeit

Eine Möglichkeit dazu Die Adresse besteht darin, das MySQLi-Objekt als Abhängigkeit an die Funktion getPosts() zu übergeben. So können Sie es machen:

function getPosts(mysqli $con) {
    // etc
}

Indem Sie das MySQLi-Objekt zu einem Parameter der Funktion machen, stellen Sie sicher, dass es im Gültigkeitsbereich der Funktion verfügbar ist und von mysqli_query() verwendet werden kann.

Zusätzliche Empfehlungen

Zusätzlich zur Lösung des Scoping-Problems sollten Sie Folgendes implementieren Empfehlungen:

  • Behandeln Sie Fehler und Verbindungsfehler, indem Sie mysqli_report() verwenden, um Fehlerberichtsoptionen festzulegen.
  • Stoppen Sie die Skriptausführung, wenn ein Verbindungsfehler oder ein Abfragefehler auftritt, indem Sie mysqli::error verwenden ().

Hier ist ein Beispiel für die Implementierung Empfehlungen:

mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT); // throw exceptions
$con=mysqli_connect("localhost","xxxx","xxxx","xxxxx");

if (!$con) {
    throw new Exception("Failed to connect to MySQL: " . mysqli_connect_error());
}

getPosts($con);

Durch die Umsetzung dieser Empfehlungen können Sie die Robustheit und Zuverlässigkeit Ihres benutzerdefinierten CMS sicherstellen.

Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3