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

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

Linda Hamilton
发布: 2024-11-01 13:44:29
原创
985 人浏览过

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

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板