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

3

我在我的登录中使用PDO(如之前的指示所述),尝试了以下代码,但仍然出现致命错误,我无法弄清楚该给它什么以满足错误:

if($query->rowCount() > 0) 
{
   // session stuff
   // refresh page
}

然后我尝试了这个:
if($query->rowCount() == 1) 
{
   // session stuff
   // refresh page
}

然而我仍然得到了这个错误信息:致命错误:在非对象上调用成员函数rowCount()

下面是我的更改之前的内容:

$count = $query->rowCount();

最后,这里有一个更好的片段,可以让你了解涉及到什么:
<?php
include("/scripts/Connections.php");

$email = $_POST['email'];
$username = $_POST['username'];
$password = md5($_POST['password'], "DDerehOjhdfDDf$$##%^)-=_/.#$#dkfsj!`~efjkf(*)/)sD");
$confPassword = md5($_POST['conPassword'], "DDerehOjhdfDDf$$##%^)-=_/.#$#dkfsj!`~efjkf(*)/)sD");

if(isset($email, $username, $password, $confPassword)) {
    if(strstr($email, "@")) {
        if($password == $confPassword) {
            $query = $dbc->prepare("SELECT * FROM members WHERE username = ? OR email = ?");
            $query = $query->execute(array(
            $username,
            $email
        ));

        $count = $query->rowCount();

        if($count == 0) {
            $query = $dbc->prepare("INSERT INTO memebers SET username = ?, email = ?, password = ?");
            $query = $query->execute(array(
                $username,
                $email,
                $password
            )); 
            if($query) {
                echo "Your account has been registered, you may login!";                
        }           
        }
        else {
            echo "A user already exists with that username/password.";
        }
    }
    else {
            echo "Your passwords do not match!";
        }
}
else {
            echo "Invalid email address!";
        }
    }           
?>

有人能指出我在这里做错了什么。这是我唯一遇到的错误。

你为什么要覆盖 $query 变量? ($query = $query->execute(array(.....) - Darren
1
下面是翻译的文本:^^ 指的是 $query = $query->execute(...),它将 $query 从一个 PDOStatement 对象转换为基于 execute() 调用成功与否的 true 或 false,并使用 rowCount() 杀死它以供以后使用。在那里使用不同的变量。 - Michael Berkowski
我明白你的意思,你是说我应该使用类似 $result = $query->execute(array(...) 这样的语句吗?基本上就是使用任何一个 $var 来保存 $query->execute 的结果。你能提供一个简短的例子吗? - Jo'vani7
2个回答

6

看起来你正在用execute()方法的布尔返回值覆盖了$query,这样会使得$query变成一个非对象值(布尔值),而你又试图在其上调用一个方法。

尝试像这样:

if($password == $confPassword) {
    $query = $dbc->prepare("SELECT * FROM members WHERE username = ? OR email = ?");

    $result = $query->execute(array(
        $username,
        $email
    ));

    // check the value of $result is true here - if not,
    // your query has failed to execute and handle the error
    // appropriately.

    $count = $query->rowCount();

    // ...
}

-1
        $query = $dbc->prepare("SELECT * FROM members WHERE username = ? OR email = ?");
        $query->execute(array($username, $email)):;
        $count = $query->rowCount();
        echo "Value is " . $count;

试试这个。

2
为什么要“尝试这个”? - Werner

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接