sql group by子句错误

时间:2014-02-04 19:48:26

标签: sql sql-server stored-procedures

这是错误

  

Msg 8120,Level 16,State 1,Procedure FollowUpdates,Line 10
  列'TopicsComplete.TopicCreationDate'在选择列表中无效,因为它不包含在聚合函数或GROUP BY子句中。

这是在添加这两行后,我需要计算一个单独的表行(行数不是topicid的计数)并在结果中包含任何想法?感谢

,COUNT(DISTINCT MC.topicid) AS NewMessagesCount

LEFT OUTER JOIN Messages AS MC ON MC.TopicId = T.TopicId AND MC.userid = @id

@id int = null
,@UserGroupId int = null
AS
SELECT
*
FROM
(SELECT
ROW_NUMBER()
        OVER ( ORDER BY TopicOrder desc
                  , CASE WHEN M.MessageCreationDate > T.TopicCreationDate 
                        THEN M.MessageCreationDate
                        ELSE T.TopicCreationDate
                    END desc )
    AS RowNumber,
T.TopicId, T.TopicTitle, T.TopicShortName, T.TopicDescription, T.TopicCreationDate, T.TopicViews, T.TopicReplies, T.UserId, T.TopicTags, T.TopicIsClose, T.TopicOrder, T.LastMessageId, T.UserName, M.MessageCreationDate, T.ReadAccessGroupId, T.PostAccessGroupId, U.UserGroupId, U.UserPhoto, T.UserFullName ,M.UserId AS MessageUserId ,MU.UserName AS MessageUserName
,COUNT(DISTINCT MC.topicid) AS NewMessagesCount

FROM            TopicsComplete AS T  
                 LEFT OUTER JOIN Messages AS M ON M.TopicId = T.TopicId AND M.MessageId = T.LastMessageId AND M.Active = 1  
                 LEFT OUTER JOIN Messages AS MC ON MC.TopicId = T.TopicId AND MC.userid = @id
                 INNER JOIN Users AS U ON U.UserId = T.UserId
LEFT JOIN Users MU ON MU.UserId = M.UserId

WHERE   EXISTS
(SELECT  * FROM    TopicsComplete
                   LEFT OUTER JOIN Messages AS M ON M.TopicId = T.TopicId AND M.MessageId = T.LastMessageId AND M.Active = 1 INNER JOIN
                   topicfollows AS TF ON T.TopicId != TF.topicid INNER JOIN
                   Users AS U ON U.UserId = T.UserId LEFT OUTER JOIN
                   Users AS MU ON MU.UserId = M.UserId
                   WHERE        (T.UserId = @id)

UNION SELECT  * FROM    TopicsComplete
                        LEFT OUTER JOIN Messages AS M ON M.TopicId = T.TopicId AND M.MessageId = T.LastMessageId AND M.Active = 1 INNER JOIN
                        topicfollows AS TF ON T.TopicId = TF.topicid INNER JOIN
                        Users AS U ON U.UserId = T.UserId LEFT JOIN 
                        Users MU ON MU.UserId = M.UserId
                        WHERE        (TF.userid = @id)
      )
) T

2 个答案:

答案 0 :(得分:1)

select中有聚合函数时,SQL Server非常合理地假设您要进行聚合。所有不在聚合函数中的列应该在group by子句中。

在您的情况下,COUNT(DISTINCT MC.topicid) AS NewMessagesCount表达式中有select。所有其他列应位于group by中。没有group by,但无论如何你都会得到错误,因为一个应该在那里。

答案 1 :(得分:0)

您需要在GROUP BY子句中包含未包含在聚合中的任何列(最大值,最小值,计数,总和等)。