我想检查指定用户的某些列是否持有高于 0 的值。
问题
在执行查询然后执行它时,我收到此错误:
Fatal error: Cannot use object of type PDOStatement as array in C:\xampp\htdocs\recover\admin\create.php on line 40
我的代码(查询+执行):
if (isset($_SESSION['user'])) {
$admin = $CONNECT_TO_DATABASE->prepare("SELECT * FROM admin WHERE username = :username");
$admin->bindValue(':username', $_SESSION['user']);
$admin->execute();
错误行(40):
if ($settings['create_admins'] > 0 || $admin['super_admin'] > 0 ) {
问题:
为什么我会收到此错误?我如何解决它?
我试过这样做:
$admin = $CONNECT_TO_DATABASE->prepare("SELECT * FROM admin WHERE username = :username");
$admin = $admin->bindValue(':username', $_SESSION['user']);
$admin = $admin->execute();
并得到另一个错误:
Fatal error: Call to a member function execute() on a non-object in C:\xampp\htdocs\recover\admin\create.php on line 38
谢谢!
编辑:我需要 ->fetch 对象,但我刚刚完成了这个,并摆脱了错误。但它不影响?我的意思是我正在呼应那一行,它给了我一个空值(什么都没有)。为什么?
$admin = $CONNECT_TO_DATABASE->prepare("SELECT * FROM admin WHERE username = ".$_SESSION['user']."");
$admin = $admin->fetch();