我有
class Check
{
public function __construct()
{
$this->db = new Database();
}
public function query()
{
$login = Session::get("login");
$sth = $this->db->prepare('SELECT admin FROM accounts WHERE login=:login');
$sth->execute(array(':login' => $login));
$result = $sth->fetch(PDO::FETCH_NUM);
return $result[0];
}
public static function admin()
{
echo self::query();
}
}
我在另一个有PDO连接的地方有数据库类.
class Database extends PDO
{
public function __construct()
{
parent::__construct('mysql:host=localhost;dbname=name','root','pass');
$this->query('SET NAMES utf8');
}
}
所以在Check :: admin()代码后我得到错误:
Undefined property: View::$db
为什么?
解决方法:
您正在使用想要使用实例变量的静态方法.
您的管理方法调用查询方法,查询方法使用db实例变量.由于您的类未实例化,因此db变量不存在.
我的建议是使管理方法不是静态的,并使用你的代码:
$mycheck = new Check();
$mycheck->admin();
或者,如果您使用的是PHP 5.4并希望坚持使用oneliner:
(new Check())->admin();
更新
注意:不要在构造函数中创建db类,而是将其注入:
public function __construct(Database $db)
{
$this->db = $db;
}
标签:php,mysql,oop
来源: https://codeday.me/bug/20190729/1570628.html