致命错误:在 null 上调用成员函数prepare()

问题描述 投票:0回答:5

我正在尝试访问类别及其内容的列表。我有一个名为“类别”的课程。我不断收到此错误。奇怪的是,到目前为止我已经在其他两个地方使用了同样的代码,没有任何问题。我在这里所做的只是重用代码并更改所有变量。

Fatal error: Call to a member function prepare() on null

这是我的班级的代码:

    <?php

class Category {
    public function fetch_all() {
        global $pdo;

        $query = $pdo->prepare("SELECT * FROM dd_cat");
        $query->execute();

        return $query->fetchAll();
    }

    public function fetch_data($cat_id) {
        global $pdo;

        $query = $pdo->prepare("SELECT * FROM dd_cat WHERE cat_id = ?");
        $query->bindValue(1, $cat_id);
        $query->execute();

        return $query->fetch();
    }
}

?>

这是我尝试调用的代码:

<?php
session_start();
//Add session_start to top of each page//
require_once('includes/config.php');
require_once('includes/header.php');
include_once('includes/category.php');

?>
<link rel="stylesheet" href="css/dd.css">
    <div id="menu">
        <a class="item" href="drop_index.php">Home</a> -
        <a class="item" href="create_topic.php">Create a topic</a> -
        <a class="item" href="create_cat.php">Create a category</a>
        <div id="userbar">
<?php
    if( $user->is_logged_in() )
    {
        echo 'Hello ' . $_SESSION['user_name'] . '. Not you? <a href="logout.php">Sign out</a>';
    }
    else
    {
        echo '<a href="login.php">Sign in</a> or <a href="index.php">create an account</a>.';
    } 
?>
        </div>
    </div>

<?php

$category = new Category;
$categories = $category->fetch_all();

?>
    <div id ="wrapper">
        <h1>Categories</h1>
        <section>
            <ul>
                <?php foreach ($categories as $category) { ?>
                    <li><a href="category.php?id=<?php echo $category['cat_id']; ?>">
                        <?php echo $category['cat_title']; ?></a> 
                    </li>
                <?php } ?>
            </ul>
        </section>
    </div>
<?php
require_once('includes/footer.php');
?>
php pdo
5个回答
45
投票

看起来您的

$pdo
变量尚未初始化。 我在您上传的代码中看不到您在哪里初始化它。

确保在调用类方法之前在

global scope
中创建一个新的 PDO 对象。 (您应该在全局范围内声明它,因为您如何实现 Category 类中的方法)。

$pdo = new PDO('mysql:host=localhost;dbname=test', $user, $pass);

2
投票

在 ---- 型号中: 添加

use Jenssegers\Mongodb\Eloquent\Model as Eloquent;

class ----- extends Model 
更改为
class ----- extends Eloquent 


0
投票

您可以尝试/捕获

PDOException
(您的配置可能有所不同,但重要的部分是尝试/捕获):

try {
        $dbh = new PDO(
            DB_TYPE . ':host=' . DB_HOST . ';dbname=' . DB_NAME . ';charset=' . DB_CHARSET,
            DB_USER,
            DB_PASS,
            [
                PDO::ATTR_PERSISTENT            => true,
                PDO::ATTR_ERRMODE               => PDO::ERRMODE_EXCEPTION,
                PDO::MYSQL_ATTR_INIT_COMMAND    => 'SET NAMES ' . DB_CHARSET . ' COLLATE ' . DB_COLLATE

            ]
        );
    } catch ( PDOException $e ) {
        echo 'ERROR!';
        print_r( $e );
    }

print_r( $e );
行将向您显示您需要的一切,例如我最近遇到一个情况,错误消息类似于
unknown database 'my_db'


0
投票

@delato468 评论必须列为解决方案,因为它对我有用。

除了定义参数外,用户在调用函数时也必须传递参数

fetch_data(PDO $pdo, $cat_id)

-1
投票

我也面临同样的问题。 对我来说, try catch 之前的 if 条件不正确。 应该是

 public static function getdb()
    {
        if(!isset(self::db)) <!-- For me it was if(isset(self::db)) i got the logic right and it worked--> 
        {
            try
            {
                
            }
            catch (PDOException $e){
                $msg = $e->getMessage();
                echo $msg;
                exit();
            }
        }
        return self::db;
    }
© www.soinside.com 2019 - 2024. All rights reserved.