首页  >  文章  >  后端开发  >  如何解决数据库连接中的“调用成员函数prepare() on null”错误?

如何解决数据库连接中的“调用成员函数prepare() on null”错误?

Linda Hamilton
Linda Hamilton原创
2024-11-01 13:44:29840浏览

How to Resolve the

空成员函数错误:数据库连接问题

遇到“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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn