我有这个表:与多行获取从关系表中的数据
博客
id
name
user_id // author - relational to "users"
用户
id
nickname
avatar
suscriptions
id
blog_id // relational to "blogs"
user_id // relational to "users"
这样做是为了显示在网站上是这样的:
Blogname
Created By Stack
Suscriptions: Overflow, Easy, Robinson, Porter
我是从blogs
SELECT
b.id,
b.name,
b.user_id,
u.nickname as user_nickname,
u.avatar as user_avatar
FROM blogs b
LEFT JOIN users u ON b.user_id = u.id
获取所有数据使用PHP,我创建的所有blogs ID
数组,因此我可以将它们与IN运算符一起使用,如下所示:
SELECT
s.id,
s.blog_id,
u.nickname,
u.avatar
FROM suscriptions s
LEFT JOIN users u ON s.user_id = u.id
WHERE s.blog_id IN (1, 2, 3)
And t再次使用PHP来排序结果。
但是,有没有更好的方法?我正在考虑只使用MySQL而不使用PHP。也许在一个查询中获取所有数据?或者什么是获得这个最好的方法?
重要的是要记住blog
可以有几个subscriptions
。
2012年我发现这个问题有点类似:JOIN three tables and aggregate data from multiple rows for every DISTINCT row in separate column 但是OP说它真的很慢,所以我现在有点迷路了。
你使用PHP核心或一些框架? –
@SulthanAllaudeen仅用于数据库处理的PDO –