0

我得到了上面显示的错误。我查看了这个网站,但我找不到解决我问题的正确方法。

我正在尝试编写一个用户。以下代码是我到目前为止的代码。

class User
{

    private $_id;

    public function __construct($id)
    {
        $this->_id = $id;
    }

    public function getUsername()
    {
        global $db;

        $query = $db->prepare("SELECT * FROM users WHERE id = ?");
        $query->bindValue(1, $this->_id);

        $query->execute();

    }

}

结果是以下错误,我不知道如何解决这个问题......

致命错误:在非对象上调用成员函数 bindValue()

编辑:

这是我使用它的方式:

$user = new User($_SESSION['logged_in']); 
$username = $user->getUsername();

旁注:session_start();已加载。

4

2 回答 2

2

使用全局变量确实是一种糟糕的方法。

阅读此博客条目:

全局变量不好

它解释了为什么这不是一个好主意。

如果$db为空,则准备很可能不会返回语句对象。

然后$query将不是一个声明,因此bindValue不会被识别。

而是将连接传递给您的班级,然后停止使用全局变量。

而且你的函数没有返回任何数据,我修改它以返回用户名。

class User
{

    private $_id;
    private $db;

    public function __construct($id, $conn)
    {
        $this->_id = $id;
        $this->$db = $conn;
    }

    public function getUsername()
    {
        $query = $this->db->prepare("SELECT username FROM users WHERE id = ?");
        $query->bindValue(1, $this->_id);

        $query->execute();
        $data = $query->fetch();

        return $data['username'];

    }

}

用法:

session_start();
$id = $_SESSION['logged_in'];
$conn = new PDO('xxx');
$user = new User($id, $conn); 
$username = $user->getUsername();
于 2014-10-23T15:48:39.653 回答
-1

对我来说,您的查询对象$db不是$query……如果是这样,那么 $query 丢失是正常的bindValue(),因为它不是对象,因此它没有任何方法。

尝试使用$db->bindValue()并告诉我们它是如何进行的:D

于 2014-10-23T15:42:04.973 回答