微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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.

原文地址:https://www.jb51.cc/mssql/74704.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐