首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >选择前10名,但11名结果

选择前10名,但11名结果
EN

Stack Overflow用户
提问于 2016-07-19 10:55:25
回答 1查看 197关注 0票数 1

我有下面的查询来选择前10。但是结果显示了11行,当我将select更改为top 20时,它显示了21行?

导致这种情况的查询有什么问题吗?

代码语言:javascript
复制
SELECT TOP 10 Format([DutyDate],"ddd"", ""dd-mmm-yy") AS [Shift Date], Count(Shifts.ID) AS Shifts
FROM Shifts
GROUP BY Format([DutyDate],"ddd"", ""dd-mmm-yy")
ORDER BY Count(Shifts.ID) DESC;
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-07-19 10:59:42

当MS Access处理TOP时,它为最后一个值放置所有的联系。在Server中,这相当于TOP WITH TIES。因此,如果第11行的计数与第10行相同,则包括--第12行等等,如果计数相同。

要解决这个问题,你需要加入一些打成平手的东西。在GROUP BY中,这就是日期。下面是一个简单的方法:

代码语言:javascript
复制
ORDER BY Count(Shifts.ID) DESC, MIN(DutyDate)
票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38456558

复制
相关文章

相似问题

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