2009-10-21 36 views
1
CREATE TABLE BlogPosts 
(
PostID INT PRIMARY KEY not null, 
PostTitle NVARCHAR , 
BlogID int, 
TotalComments int 
) 

可以使用任何联接而不是相关子查询简化此查询吗?加入而不是相关的子查询

SELECT TOP 5 * 
FROM BlogPosts as t0 
WHERE t0.PostID = (SELECT TOP 1 t1.PostID 
       FROM BlogPosts as t1 
       WHERE t0.BlogID = t1.BlogID 
       ORDER BY t1.TotalComments DESC) 

我需要5个帖子,最多TotalComments来自不同的博客。

UPD。 SQL Server中,但我宁愿标准SQL

+0

什么是RBDMS? SQL Server? – Asaph

+0

你声明的sql没有排序,所以前五个不能保证返回任何特定的五行......可能有更多的5行满足Where子句......正如你写的那样,你可能会从同一个博客中获取所有五个或混合。你想要哪一个? –

+0

不,我需要来自不同博客的顶级评论文章,不是来自同一个博客,否则它会更容易:) – rudnev

回答

1

如果我理解正确的,帖子ID是唯一的,所以这应该有助于

编辑:

OK试试这个,然后

DECLARE @BlogPosts TABLE 
( 
    PostID INT PRIMARY KEY not null, 
    PostTitle NVARCHAR , 
    BlogID int, 
    TotalComments int 
) 

INSERT INTO @BlogPosts (PostID,PostTitle,BlogID,TotalComments) SELECT 1, 'A', 1, 3 
INSERT INTO @BlogPosts (PostID,PostTitle,BlogID,TotalComments) SELECT 2, 'B', 1, 4 
INSERT INTO @BlogPosts (PostID,PostTitle,BlogID,TotalComments) SELECT 3, 'C', 2, 5 
INSERT INTO @BlogPosts (PostID,PostTitle,BlogID,TotalComments) SELECT 4, 'D', 2, 6 
INSERT INTO @BlogPosts (PostID,PostTitle,BlogID,TotalComments) SELECT 5, 'E', 2, 7 
INSERT INTO @BlogPosts (PostID,PostTitle,BlogID,TotalComments) SELECT 6, 'F', 1, 8 
INSERT INTO @BlogPosts (PostID,PostTitle,BlogID,TotalComments) SELECT 7, 'G', 3, 9 
INSERT INTO @BlogPosts (PostID,PostTitle,BlogID,TotalComments) SELECT 8, 'H', 4, 10 
INSERT INTO @BlogPosts (PostID,PostTitle,BlogID,TotalComments) SELECT 9, 'I', 5, 11 
INSERT INTO @BlogPosts (PostID,PostTitle,BlogID,TotalComments) SELECT 10, 'J', 6, 5 

SELECT TOP 5 * 
FROM @BlogPosts bp INNER JOIN 
     (
      SELECT BlogID, 
        MAX(TotalComments) MaxComments 
      FROM @BlogPosts 
      GROUP BY BlogID 
     ) maxCommentsPerBlog ON bp.BlogID = maxCommentsPerBlog.BlogID 
          AND bp.TotalComments = maxCommentsPerBlog.MaxComments 
ORDER BY bp.TotalComments DESC 

你可能有尽管多个最大的blog-totalComments组合。

+0

@astander:为什么“@BlogPosts”而不是“BlogPosts”?这不是临时表。 – Asaph

+0

这是我在TSQL –

+0

中的测试表,你可能在这里有相同的博客。我说不同的博客 – rudnev

1

这会给你每博客上一篇:

SELECT * FROM (
    SELECT *, Ranking = ROW_NUMBER() OVER (PARTITION BY BlogID ORDER BY TotalComments DESC) 
    FROM BlogPosts 
) a 
WHERE Ranking = 1 

或者:

SELECT b.* 
FROM (
    SELECT DISTINCT BlogID 
    FROM BlogPosts 
) a 
CROSS APPLY (
    SELECT TOP 1 b.* FROM BlogPosts b 
    WHERE a.BlogID = b.BlogID 
    ORDER BY b.TotalComments DESC 
) b 

这就是你想要的?

+0

随着分区它是很好,谢谢,可能会比加入更好。 – rudnev

0

为什么你需要连接和子查询? 为什么你不能写

SELECT TOP 5 * 
FROM @BlogPosts bp order by TotalComments desc; 
+0

可能是因为@rudnev需要来自不同博客的前5名“。您的查询可能会返回仅有一个博客排名前5位。 –