我借用了一个查询并根据自己的目的进行了调整,但是当我不完全确定它在做什么时,我不喜欢这样做. 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 举报,一经查实,本站将立刻删除。