sql – 有人可以解释一下

我借用了一个查询并根据自己的目的进行了调整,但是当我不完全确定它在做什么时,我不喜欢这样做. 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.

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...