0

我的表结构:

posts (id, name, user_id, about, time)    
comments (id, post_id, user_id, text, time)
users_votes (id, user, post_id, time)
users_favs ( id, user_id, post_id, time)

我怎样才能结合这四个查询(不是UNION):

SELECT `id`, `name`, `user_id`, `time` FROM `posts` WHERE `user_id` = 1
SELECT `post_id`, `user_id`, `text`, `time` FROM `comments` WHERE `user_id` = 1
SELECT `user`, `post_id`, `time` FROM `users_votes` WHERE `user` = 1
SELECT `user_id`, `post_id`, `time` FROM `users_favs` WHERE `user_id` = 1

我应该使用JOINs 吗?

对此的 SQL 查询是什么?

4

1 回答 1

2

你不想把这些结合在一起。

JOIN您用来检索它的那种最终会对其找到的所有行进行交叉乘积。这意味着,如果您有 4 个帖子、2 个评论、3 个投票和 6 个收藏夹,那么在执行单独查询时,您的结果中将获得 4*2*3*6 行,而不是 4+2+3+6。

您唯一想要的JOIN是当这两件事本质上相关时。也就是说,您想要检索与收藏夹、投票或评论相关联的帖子。

根据您的示例,这些事情没有这样的共性。

于 2013-05-03T00:13:39.753 回答