php - PDO - fatal error : Call to a member function prepare() on null

标签 php mysql pdo

我在这里搜索了类似的问题,但无法解决我的问题。

我正在尝试向我的网站添加搜索功能,但由于某种原因,搜索结果未显示。在我的 error_log 中,我收到此错误:

PHP Fatal error: Call to a member function prepare() on null in /home/..../search.php on line 9

这是哪一行:

$query = $pdo->prepare("SELECT * FROM subs WHERE sub_title LIKE '%$search%' LIMIT 0, 10");

这是我的 search.php 代码:

<?php
require_once('includes/config.php'); 
include("includes/header.php");

// Search from MySQL database table
$search = $_POST['search'];
$query = $pdo->prepare("SELECT * FROM subs WHERE sub_title LIKE '%$search%' LIMIT 0, 10");
$query->bindValue(1, "%$search%", PDO::PARAM_STR);
$query->execute();

// Display search result 
if(!$query->rowCount() == 0) {
echo "Search found:<br>";
echo "<table>";
echo "<tr><td>Title</td><td>Category></td><td>Language</td><td>Time</td><td>Download</td></tr>";
while($results = $query->fetch()) {
    echo "<tr><td>";
    echo $results['sub_title'];
    echo "</td><td>";
    echo $results['category'];
    echo "</td><td>";
    echo $results['sub_lang'];
    echo "</td><td>";
    echo $results['timestamp'];
    echo "</td><td>";
    echo $results['sub_data'];
    echo "</td></tr>";
}

echo "</table>";
} else {
echo "Nothing found";
}

?>

这是我的 config.php

<?php 
$username = '------';
$password = '------';

try {
$conn = new PDO('mysql:host=localhost;dbname=-----', $username, $password, array(
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION
));
}

catch(PDOException $e) {
echo "Failed to connect to database!" . "<br><br>";
echo $e->getMessage();
}
?>

这是我的搜索表单,位于 header.php

<form class="form-inline" action="search.php" method="POST">
     <input class="form-control" name="search" id="search" type="text" placeholder="Search">
 </form>

最佳答案

您正在使用:$query = $pdo->prepare

应该是:

$query = $conn->prepare()

因为我是一个懒惰的编码员,所以我创建了一个新类来节省一些时间:

class DBCommon
{
    private $conn;

    /** @var Common */
    public $common;

    public function __construct()
    {
        $database = new Database();
        $db = $database->dbConnection();
        $this->conn = $db;
    }

    public function runQuery($sql)
    {
        $stmt = $this->conn->prepare($sql);
        return $stmt;
    }
}

关于php - PDO - fatal error : Call to a member function prepare() on null,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41140045/

相关文章:

javascript - jQuery/PHP : How to return upload file information properly

mysql - 使用 Workbench 将 MS Access 迁移到 MySQL 时出现日期时间错误

mysql - 使用PDO将变量绑定(bind)到LIMIT

PHP PDO 动态 WHERE 子句

javascript - 将附加行添加到数据库时如何插入附加信息

php - 将 Laravel 部署到 Azure

php - 在网页上的 HTML 表中显示 MySQL 数据库表中的值

php - 在 PHP 中创建长度为 5 的唯一 id

MySQL 事件调度程序每天运行 10 次

傻瓜版 PHP PDO