Home >Backend Development >PHP Tutorial >Why Does My MySQLi Code Throw 'mysqli::query(): Couldn't fetch mysqli' Errors?
The error message "mysqli::query(): Couldn't fetch mysqli in line 43" signifies a connection problem with the MySQL database.
The code segment mentioned includes a connection file ("inc_LadleDB.php") and a class ("EventCalendar") that interacts with the database. Here's the relevant code:
// Connection file $DBConnect = @new mysqli("localhost", "root@localhost", NULL, "Ladle"); // Class constructor function __construct() { include("inc_LadleDB.php"); $this->DBConnect = $DBConnect; } // Class destructor function __destruct() { if (!$this->DBConnect->connect_error) { $this->DBConnect->close(); } }
The error arises due to the database connection being closed prematurely, specifically in the destructor method "__destruct()". When the object is destroyed, it closes the database connection, but subsequent queries continue to attempt to execute, leading to the error.
To resolve the issue, ensure that the database connection remains open during the execution of all queries. One possible solution is to remove the "close()" statement from the destructor. Consider the following modification:
// Class destructor function __destruct() { // Do not close the connection here }
Remember, the "__destruct()" method is automatically called when an object is destroyed, so closing the connection there may lead to errors if other queries or database operations are still being performed.
The above is the detailed content of Why Does My MySQLi Code Throw 'mysqli::query(): Couldn't fetch mysqli' Errors?. For more information, please follow other related articles on the PHP Chinese website!