MySQL JOIN无法正常工作

时间:2014-10-06 19:46:29

标签: php mysql sql

我正在尝试从一个表到另一个表完成MySQL连接,但它无法正常工作。理想情况下,我希望能够处理准备好的语句(因为它更安全)但是现在我只是想让它正常工作。

这是我的数据库设置:

帖子:

id | title | text 

1  | Evening | Something here...
2  | Trip away | Bets place to go...

标签:

post_id | tag
1       | weather 
1       | Autumn 
2       | Holidays

这是我到目前为止的尝试:

  $tag = mysqli_real_escape_string($_GET['tag']);
  $select = mysqli_query($mysqli, "SELECT posts.id, posts.title FROM posts INNER JOIN tags ON tags.tag = ".$tag);

然而,这不起作用。 我要做的是选择所有已搜索相关标签的帖子,然后将其输出给用户。请帮助我真的被卡住了

编辑:循环输出数据

  $select = mysqli_query($mysqli, "SELECT posts.id, posts.title FROM posts INNER JOIN tags ON tags.post_id = posts.id WHERE tags.tag = ".$tag);

  while($row = mysqli_fetch_array($select)) {

    echo print_r($row);

  }

1 个答案:

答案 0 :(得分:3)

您的内部联接语法不正确

SELECT posts.id, posts.title 
FROM posts 
INNER JOIN tags ON tags.post_id = posts.id 
WHERE tags.tag = "some_tag_here"

您需要将两个表连接在一起,然后使用WHERE按标签过滤