Rumah >pembangunan bahagian belakang >tutorial php >Mengapa saya mendapat \'Ralat maut: Panggilan ke fungsi ahli prepare() pada null\' apabila cuba mendapatkan semula kategori?

Mengapa saya mendapat \'Ralat maut: Panggilan ke fungsi ahli prepare() pada null\' apabila cuba mendapatkan semula kategori?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-10-30 16:49:03219semak imbas

Why am I getting a

Ralat Maut: Panggilan Misteri ke Fungsi Ahli Batal

Pertanyaan:

Saya' m menghadapi ralat yang membingungkan "Ralat maut: Panggil ke fungsi ahli sediakan() pada nol" apabila cuba mendapatkan semula senarai kategori menggunakan kod ini:

<code class="php">$category = new Category;
$categories = $category->fetch_all();</code>

Konteks:

Kelas Kategori mempunyai kaedah berikut:

<code class="php">class Category {
    public function fetch_all() {
        global $pdo;
        $query = $pdo->prepare("SELECT * FROM dd_cat");
        ...
    }

    public function fetch_data($cat_id) {
        global $pdo;
        $query = $pdo->prepare("SELECT * FROM dd_cat WHERE cat_id = ?");
        ...
    }
}</code>

Saya telah menggunakan kod ini dengan jayanya dalam dua bahagian lain projek saya, tetapi ia memberi saya masalah di sini.

Respons:

Isu timbul kerana pembolehubah $pdo adalah batal. Ia mesti dimulakan dengan objek PDO sebelum kaedah kelas boleh dipanggil. Ini disebabkan oleh cara kaedah telah dilaksanakan dalam kelas Kategori.

Untuk membetulkan ralat, tambahkan kod berikut pada skrip anda:

<code class="php">$pdo = new PDO('mysql:host=localhost;dbname=test', $user, $pass);</code>

Pastikan kod ini diletakkan dalam skop global, sebelum sebarang panggilan ke kaedah kelas Kategori.

Atas ialah kandungan terperinci Mengapa saya mendapat \'Ralat maut: Panggilan ke fungsi ahli prepare() pada null\' apabila cuba mendapatkan semula kategori?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn