空成员函数错误:数据库连接问题
遇到“Call to a member function prepare() on null”错误时,问题通常源于类实例中未初始化的变量。在您的情况下,问题在于 $pdo 变量缺少初始化。
在您的 Category 类中, fetch_all() 和 fetch_data() 方法都需要 PDO 连接。但是,提供的代码没有显式建立此连接。要解决此错误,您需要确保在调用类方法之前在全局范围内初始化 $pdo 变量。
<code class="php"><?php // Instantiate a new PDO object globally $pdo = new PDO('mysql:host=localhost;dbname=test', $user, $pass); class Category { public function fetch_all() { global $pdo; // Use the initialized $pdo variable to prepare the SQL query $query = $pdo->prepare("SELECT * FROM dd_cat"); $query->execute(); return $query->fetchAll(); } public function fetch_data($cat_id) { global $pdo; // Use the initialized $pdo variable to prepare the SQL query $query = $pdo->prepare("SELECT * FROM dd_cat WHERE cat_id = ?"); $query->bindValue(1, $cat_id); $query->execute(); return $query->fetch(); } } ?></code>
通过全局初始化 $pdo 变量并确保在类内使用它方法,您将建立正确的数据库连接并解决“Call to a member function prepare() on null”错误。
以上是如何解决数据库连接中的“调用成员函数prepare() on null”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!