0

表“posts”包含文章和对每篇文章发表评论的人的最后 3 个用户 ID(us1、us2、us3)。我需要加入“usertable”以获取最后评论海报的名称。这是我的查询:

$result = mysql_query("SELECT m.id, m.comment, m.us1, m.us2, m.us3,p.name,o.name,t.name,
FROM posts m 
LEFT JOIN usertable p ON m.us1=u.id
LEFT JOIN usertable o ON m.us2=u.id
LEFT JOIN usertable t ON m.us3=u.id   

where m.lid = '$pid' order by m.id desc limit 0,20")  or die('Error');

while(list($id, $comment, $us1, $us2, $us3, $name1, $name2, $name3) = mysql_fetch_row($result)) {
echo "$id<br />";
}

不幸的是,这个结果的“回声”是:

79
79
79
79
79...

“79”是“posts”表中最后一行的ID。那么,为什么这个查询的结果只是从“posts”中选择了一行呢?

4

1 回答 1

0

当此图中没有表“U”时,您的 SQL 引用“u.id”存在问题。尝试:

SELECT m.id, m.comment, m.us1, m.us2, m.us3, p.name, o.name, t.name
FROM posts m 
LEFT JOIN usertable p ON m.us1=p.id
LEFT JOIN usertable o ON m.us2=o.id
LEFT JOIN usertable t ON m.us3=t.id

此外,切换到 mysqli_* 函数而不是 mysql_ 因为 mysql 扩展已被弃用并且很快将被删除。PDO 也值得一看。在 php.net 上检查这两个。

于 2013-03-13T09:46:30.720 回答