加入后 MySQL 限制 LEFT JOIN 子查询

Posted

技术标签:

【中文标题】加入后 MySQL 限制 LEFT JOIN 子查询【英文标题】:MySQL Limit LEFT JOIN Subquery after joining 【发布时间】:2013-04-07 15:47:55 【问题描述】:

目前我有这个查询:

SELECT post.id AS postID, sCom.id as CommentID FROM `post` LEFT JOIN (SELECT * FROM `comment` LIMIT 5) AS sCom ON sCom.post_id = post.id;

输出:

postID | CommentID
1      | 1
2      | null
3      | null
4      | 2
5      | 3
5      | 4
5      | 5

它有效,但它在加入之前限制了评论表。结果是,它选择了前 5 个 cmets 并对其进行映射。 id 为 5 的所有 cmets 都会被忽略。

如何重写查询以选择最多 5 个 cmets 的帖子?

当前表结构:

发帖:

如果不存在 `post` 则创建表 ( `id` int(11) NOT NULL AUTO_INCREMENT, `feed_id` int(11) 默认为空, `user_id` int(11) 默认为 NULL, `origin_id` int(11) 默认为 NULL, `content` longtext COLLATE utf8_unicode_ci NOT NULL, `启用` tinyint(1) NOT NULL, `created_at` 日期时间不为空, `updated_at` 日期时间不为空, 主键(`id`), KEY `IDX_5A8A6C8D51A5BC03` (`feed_id`), KEY `IDX_5A8A6C8DA76ED395` (`user_id`), KEY `IDX_5A8A6C8D56A273CC`(`origin_id`) ) 引擎=InnoDB 默认字符集=utf8 排序=utf8_unicode_ci AUTO_INCREMENT=6 ;

评论:

如果不存在 `comment` 则创建表 ( `id` int(11) NOT NULL AUTO_INCREMENT, `feed_id` int(11) 默认为空, `user_id` int(11) 默认为 NULL, `post_id` int(11) 默认为 NULL, `content` longtext COLLATE utf8_unicode_ci NOT NULL, `启用` tinyint(1) NOT NULL, `created_at` 日期时间不为空, `updated_at` 日期时间不为空, 主键(`id`), KEY `IDX_9474526C51A5BC03` (`feed_id`), KEY `IDX_9474526CA76ED395` (`user_id`), KEY `IDX_9474526C4B89032C`(`post_id`) ) 引擎=InnoDB 默认字符集=utf8 排序=utf8_unicode_ci AUTO_INCREMENT=11 ;

谢谢

【问题讨论】:

【参考方案1】:

这将为每个帖子提供 5 cmets。

SELECT  p.*,
        c.*
FROM    Post p
        LEFT JOIN
        (
            SELECT  a.*
            FROM    Comments a
            WHERE    
                    (
                       SELECT   COUNT(*) 
                       FROM     Comments b
                       WHERE    a.Post_ID = b.Post_ID AND 
                                a.ID <= b.ID
                    ) <= 5
        ) c ON  a.ID = c.Post_ID

【讨论】:

@JohnWoo 谢谢,这对我有帮助,但我认为a.ID = c.Post_ID 必须是p.ID = c.Post_ID @JohnWoo 我觉得你是this question 的人(请参阅链接),你的回答应该对我有帮助,但我就是想不通。我有一个 LIKE 让事情变得复杂。

以上是关于加入后 MySQL 限制 LEFT JOIN 子查询的主要内容,如果未能解决你的问题,请参考以下文章

MySql 之 left join 查询结果

LEFT JOIN 两个 MySql 表,而第二个表按 desc 排序并限制为 1

MySQL # left join 语句,对右表的限制条件使用注意问题

Mysql - LEFT JOIN 比 INNER JOIN 快

mysql的inner join,left jion,right join,cross join以及on和where的区别

MYSQL Left Join 如何选择 NULL 值?