我借用了一个查询并根据自己的目的进行了调整,但是当我不完全确定它在做什么时,我不喜欢这样做. sql文档对此子句的描述不够.这是我借用和修改的内容,你能告诉我它基本上在做什么吗?
(SELECT Id FROM ( SELECT Id,RANK() OVER ( PARTITION BY DropStatusId ORDER BY StatusDate DESC) [Rank] FROM [dbo].[tblLHTrackingHistory] [TempHistory] WHERE [TempHistory].[DropStatusId] = [DropStatus].[Id] ) [TT1] WHERE [Rank] = 1 )
解决方法
OVER子句意味着您正在使用分析(比如聚合).按
OVER documentation:
Determines the partitioning and ordering of the rowset before the associated window function is applied.
与聚合不同,分析不需要定义GROUP BY.