【问题标题】:Left joining count(*) from second table从第二个表左加入计数(*)
【发布时间】:2021-02-26 15:49:29
【问题描述】:

我正在尝试从表一(帖子)的单行返回字段,并将该帖子的第二个表(cmets)中出现的 cmets 数加入该行。

但是,它从不返回计数值。

SELECT posts.post_title, posts.post_author, posts.post_date, posts.post_article
FROM posts LEFT OUTER JOIN (SELECT COUNT(*) FROM comments WHERE comments.comment_post_id = 25) AS comments
ON posts.post_id = comments.comment_post_id WHERE post_id = 25; 

我知道我可能遗漏了一些简单的东西,但已经在这方面花费了太多时间,所以我想寻求帮助。由于我是 SQL 新手,我非常感谢您的解释以及任何代码更改建议。

【问题讨论】:

    标签: sql join count


    【解决方案1】:

    我建议使用相关子查询:

    SELECT p.post_title, p.post_author, p.post_date, p.post_article,
           (SELECT COUNT(*)
            FROM comments c
            WHERE c.comment_post_id = p.post_id
           ) as num_comments
    FROM posts p
    WHERE p.post_id = 25;
    

    这有效地允许您在查询中只使用一次25 - 减少编码错误的范围。

    您的代码不起作用,因为您没有选择外部SELECT 中的计数列。请记住:SQL 查询描述了结果集。如果SELECT 中没有列或表达式,则不会被选中。

    【讨论】:

    • 简洁且像魅力一样工作!同样感谢您的解释 - 根据您的建议,我一直在阅读处理语句的顺序。
    【解决方案2】:

    好吧,您不需要外连接,因为 count si 查询将只有一行。假设你想这样做,然后在你的子查询中包含 post_id。

    SELECT posts.post_title, posts.post_author, posts.post_date, posts.post_article, ncomments
    FROM posts LEFT OUTER JOIN (SELECT post_id, COUNT(*) as ncomments FROM comments WHERE comments.comment_post_id = 25) AS comments
    ON posts.post_id = comments.comment_post_id WHERE post_id = 25; 
    

    否则,我认为应该这样做:

    但是,它从不返回计数值。

    SELECT posts.post_title, posts.post_author, posts.post_date, posts.post_article, ncomments
    FROM posts INNER JOIN (SELECT COUNT(*) AS ncomments FROM comments WHERE comments.comment_post_id = 25) AS comments
    

    【讨论】:

      【解决方案3】:

      解决这个问题的两种方法..

      一种方法和快速的解决方案..

      SELECT posts.post_title, posts.post_author, posts.post_date, posts.post_article,(SELECT COUNT(*) FROM comments WHERE comments.comment_post_id = posts.comment_post_id)CountComment
      FROM posts post
      WHERE post_id = 25;
      

      最好的解决方案..

      select mainQueryPosts.post_title, mainQueryPosts.post_author, mainQueryPosts.post_date, mainQueryPosts.post_article,mainQueryPosts.count,mainQueryPosts.rownumber
      from (
      SELECT posts.post_title, posts.post_author, posts.post_date, posts.post_article,count(*) over (partition by comments.comment_post_id) count, ROW_NUMBER() OVER (partition by comments.comment_post_id ORDER BY comments.CreateDate) rownumber
      FROM posts  inner join comments  on comments.comment_post_id = post.comment_post_id
      WHERE post_id = 25
      ) mainQueryPosts
      where mainQueryPosts.rownumber=1
      

      纳德加里比安法德

      【讨论】:

        猜你喜欢
        • 2020-06-27
        • 2012-04-24
        • 2014-11-26
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2018-01-22
        • 1970-01-01
        • 2018-06-06
        相关资源
        最近更新 更多