首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >1文章中有许多文章--

1文章中有许多文章--
EN

Stack Overflow用户
提问于 2015-12-28 15:01:46
回答 1查看 31关注 0票数 0

下面是这个query语句中包含的3个表

  • 帖子:Id,标题,帖子,RatingId,Img
  • 评级:Id,UserId,PostId

一篇文章有多个评级,我们想要计数与文章itselfs有关的所有信息的评级。

这就是我所拥有的:

代码语言:javascript
复制
SELECT p.*, Count(r.PostId)
FROM Posts p INNER JOIN
     Rating r
     on p.RatingId = r.PostId

然后我得到了这个错误:

Msg 8120、级别16、状态1、第1列'Posts.Id‘在select列表中无效,因为它既不包含在聚合函数中,也不包含在GROUP BY子句中。

但是我不想使用组by,我想返回文章信息以及该文章评等计数的一列。

谢谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-12-28 15:06:59

可能最简单的方法是使用子查询来完成您想要的事情:

代码语言:javascript
复制
SELECT p.*,
       (SELECT Count(r.PostId)
        FROM rating r
        WHERE p.RatingId = r.PostId
       )
FROM Posts p ;

您的查询有一个问题,因为它使用了聚合函数COUNT()和其他列(p.*),并且没有GROUP BY子句。

而且,您的JOIN状态看起来非常奇怪。我希望p.PostId = r.PostIdp.Id = r.PostId

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34495852

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档