小编典典

调用非对象上的成员函数rowCount()

sql

我的查询有问题。我最近改用了PDO,这对我来说是新的。现在,我需要在查询中使用JOIN来从另一个表中获取数据,而无需执行两次执行。

问题是,我收到此错误:

Call to a member function rowCount() on a non-object

我不明白问题是什么。这是我的代码的样子:

  $friends_string = "SELECT * FROM `friends` as F, `users` as U WHERE `F.userID` = '$sess_user' AND `F.request` = '0' AND `F.friendID` = 'U.id'";
  $friends = $db->query($friends_string);
  if ($friends->rowCount() > 0) {

while($row = $friends->fetch(PDO::FETCH_ASSOC)) {
    echo "<br /><a href='profile.php?id={$row["id"]}'>{$row["friendID"]}</a>";
  }

} else {
    echo "no Friends";
}

或简称为查询:

SELECT * FROM `friends` as F, `users` as U WHERE `F.userID` = '$sess_user' AND `F.request` = '0' AND `F.friendID` = 'U.id'

我想要的是,从用户ID为session且请求为0的朋友那里获取所有行。但是然后我想获取用户中那些朋友的ID,以便我可以链接到他们的个人资料。注意$row["id"]

感谢您提供任何反馈意见,不必回答我的问题,如果您发现任何问题,请发表评论。谢谢!


阅读 329

收藏
2021-04-14

共1个答案

小编典典

不要在“ table.field”周围放回刻度线…您必须将它们放在“ table.field”周围。

2021-04-14