我有下面的查询来选择前10。但是结果显示了11行,当我将select更改为top 20时,它显示了21行?
导致这种情况的查询有什么问题吗?
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;发布于 2016-07-19 10:59:42
当MS Access处理TOP时,它为最后一个值放置所有的联系。在Server中,这相当于TOP WITH TIES。因此,如果第11行的计数与第10行相同,则包括--第12行等等,如果计数相同。
要解决这个问题,你需要加入一些打成平手的东西。在GROUP BY中,这就是日期。下面是一个简单的方法:
ORDER BY Count(Shifts.ID) DESC, MIN(DutyDate)https://stackoverflow.com/questions/38456558
复制相似问题