有效地包含不在SQL查询的Group By中的列
发布时间:2021-01-22 20:55:07 所属栏目:MsSql教程 来源:网络整理
导读:特定 表A. Id INTEGERName VARCHAR(50) 表B. Id INTEGERFkId INTEGER ; Foreign key to Table A 我想计算每个FkId值的出现次数: SELECT FkId,COUNT(FkId) FROM B GROUP BY FkId 现在我只想输出表A中的Name. 这不起作用: SELECT FkId,COUNT(FkId),a.NameFROM
|
特定 表A. Id INTEGER Name VARCHAR(50) 表B. Id INTEGER FkId INTEGER ; Foreign key to Table A 我想计算每个FkId值的出现次数: SELECT FkId,COUNT(FkId) FROM B GROUP BY FkId 现在我只想输出表A中的Name. 这不起作用: SELECT FkId,COUNT(FkId),a.Name FROM B b INNER JOIN A a ON a.Id=b.FkId GROUP BY FkId 因为a.Name不包含在GROUP BY子句中(生成在选择列表中无效,因为它不包含在聚合函数或GROUP BY子句错误中). 重点是从这样的输出转移 FkId Count 1 42 2 25 输出像这样 FkId Count Name 1 42 Ronald 2 22 John 对于该错误消息,在SO上存在相当多的匹配,但是例如https://stackoverflow.com/a/6456944/141172有一些评论,如“将在桌面上产生3次扫描,而不是1,因此不会缩放”. 如何在查询输出中有效地包含联接表B中的字段(与FkId具有1:1的关系)? 解决方法你可以尝试这样的事情:;WITH GroupedData AS
(
SELECT FkId,COUNT(FkId) As FkCount
FROM B
GROUP BY FkId
)
SELECT gd.*,a.Name
FROM GroupedData gd
INNER JOIN dbo.A ON gd.FkId = A.FkId
创建一个CTE(公用表表达式)来处理表B上的分组/计数,然后将该结果(每个FkId一行)连接到表A,并从表A中获取更多列到最终结果集中. (编辑:天瑞地安资讯网_保定站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
站长推荐
- sql-server-2008 – 如何修改此t-sql查询以返回不
- sql-server – 您可以在数据透视表中小计行和/或
- sql-server – 从大数据集中删除重复项(gt; 100M
- 网页制作中使用规范的HTML代码的几点
- sql-server – 对于SELECT INTO表查询,WHERE 1 =
- sql-server-2005 – 永久删除表时回收SQL Server
- SQL Server下split函数功能与用法是什么?
- 如何在LINQ to Entity Framework中使用SQL通配符
- SQL中的表扫描和索引扫描
- sql-server – sql server express localdb.msi离
热点阅读

