当前位置: 首页 > 知识库问答 >
问题:

MySQL限制加入后的左加入子查询

纪正德
2023-03-14

目前我有以下查询:

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个注释并映射它。id为5的所有评论将被忽略。

CREATE TABLE IF NOT EXISTS `post` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `feed_id` int(11) DEFAULT NULL,
 `user_id` int(11) DEFAULT NULL,
 `origin_id` int(11) DEFAULT NULL,
 `content` longtext COLLATE utf8_unicode_ci NOT NULL,
 `enabled` tinyint(1) NOT NULL,
 `created_at` datetime NOT NULL,
 `updated_at` datetime NOT NULL,
 PRIMARY KEY (`id`),
 KEY `IDX_5A8A6C8D51A5BC03` (`feed_id`),
 KEY `IDX_5A8A6C8DA76ED395` (`user_id`),
 KEY `IDX_5A8A6C8D56A273CC` (`origin_id`)
) ENGINE=InnoDB  DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=6 ;
CREATE TABLE IF NOT EXISTS `comment` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `feed_id` int(11) DEFAULT NULL,
 `user_id` int(11) DEFAULT NULL,
 `post_id` int(11) DEFAULT NULL,
 `content` longtext COLLATE utf8_unicode_ci NOT NULL,
 `enabled` tinyint(1) NOT NULL,
 `created_at` datetime NOT NULL,
 `updated_at` datetime NOT NULL,
 PRIMARY KEY (`id`),
 KEY `IDX_9474526C51A5BC03` (`feed_id`),
 KEY `IDX_9474526CA76ED395` (`user_id`),
 KEY `IDX_9474526C4B89032C` (`post_id`)
) ENGINE=InnoDB  DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=11 ;

谢谢

共有1个答案

闽经纬
2023-03-14

这将给你每个帖子5个评论。

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
 类似资料:
  • 问题内容: 假设我有两个表一对一的关系。 而且,我想从每个主记录中选择列,并从相关表中选择第一个记录。 我尝试了一些方法,但没有成功…… 在这里,我结束了这个SQL提琴: http://sqlfiddle.com/#!2/39fdb/3 那里的问题是它不能从子选择中引用a.ID。 当然,这行不通,但这只是我能想到的 关于如何解决它的任何想法? 问题答案: 不可以,您无法在与相连的子选择中进行引用。

  • 我有两张这样的桌子: 我需要根据一些标准获取CHANGESET记录列表,并且只加入一个DECISION记录,最后一个基于dateTimeStamp。 所以,我有一个这样的查询: 或者,我可以使用以下查询获得相同的结果: 我需要的是用QueryDSL编写它。我尝试了这样的方法: 并加入到: 但它根本不起作用,因为或不基于

  • 问题内容: 我有两个要加入的表。 我想要类别表中的所有类别以及用户在category_subscriptions表中订阅的所有类别。 基本上这是我到目前为止的查询: 这很好用,但是我想在查询的末尾添加一个where子句,然后从本质上使它成为一个内部/等参连接。 如何仅使用一个查询获取所有类别以及特定用户订阅的所有类别? category_id是类别表和user_category_subscript

  • 我有2表连接在一起(订单和Order_item)当我使用连接我得到重复的记录,然后我消除他们与,但当我想得到总和不工作,因为它只是消除了相同的价格值,我所有的价格都是一样的,我得到1不是总和! 如果我不使用,我将按顺序获取每个项目的行 如何正确得到运费总和... 订单表中的数据是 sum=600,但如何获得它,如果我没有区分,我会在每个

  • 问题内容: 一个供您所有MySQL专家使用的技巧:-) 我有以下查询: 订单表= 80,900行 产品表= 125,389行 o.id和p.order_id已建立索引 该查询大约需要6秒钟才能完成-太长了。我正在寻找一种优化它的方法,可能使用临时表或其他类型的联接。恐怕我对这两个概念的理解还很有限。 谁能建议我优化此查询的方法? 问题答案: 首先,我将使用其他样式的语法。 已经有20年的睡眠时间了

  • 问题内容: 我有以下型号: 我想查询所有未分配志愿者的部门。我可以使用以下查询进行操作: 有没有一种更像django的方式做到这一点,还是我应该只使用原始sql? 问题答案: 您可以通过遵循查找中的向后关系来执行此操作。 以下是有关“跨多值关系”查询的文档:https : //docs.djangoproject.com/en/stable/topics/db/queries/#spanning-