1. ホーム
  2. php

[解決済み] [Solved] Fatal error: メンバ関数prepare()のNULLでの呼び出し

2022-01-20 17:07:47

質問

カテゴリとそのコンテンツのリストにアクセスしようとしています。Categoriesというクラスを持っています。このエラーが出続けます。奇妙なことに、これと全く同じコードを、これまで他の2つの場所で何の問題もなく使用してきました。私がここでしたことは、コードを再利用し、すべての変数を変更したことだけです。

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');
?>

解決方法は?

あなたの $pdo 変数が初期化されていません。 アップロードされたコードには、初期化している箇所が見当たりません。

に新しい PDO オブジェクトを作成したことを確認します。 global scope クラスメソッドを呼び出す前に (Categoryクラス内のメソッドをどのように実装したかにより、グローバルスコープで宣言する必要があります)。

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