我正在尝试从一个表到另一个表完成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);
}
答案 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按标签过滤