加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SQL:Last_Value()返回错误的结果(但First_Value()工作正常)

发布时间:2020-12-12 06:01:45 所属栏目:MsSql教程 来源:网络整理
导读:我在SQL Server 2012中有一个表,如快照所示: 然后我使用Last_Value()和First Value来获取不同YearMonth的每个EmpID的AverageAmount.脚本如下: SELECT A.EmpID,First_Value(A.AverageAmount) OVER (PARTITION BY A.EmpID Order by A.DimYearMonthKey asc) AS
我在SQL Server 2012中有一个表,如快照所示:

然后我使用Last_Value()和First Value来获取不同YearMonth的每个EmpID的AverageAmount.脚本如下:

SELECT A.EmpID,First_Value(A.AverageAmount) OVER (PARTITION BY A.EmpID Order by A.DimYearMonthKey asc) AS  '200901AvgAmount',Last_Value(A.AverageAmount) OVER (PARTITION BY A.EmpID Order by A.DimYearMonthKey asc) AS '201112AvgAmount'

FROM  Emp_Amt  AS A

但是,此查询的结果是:

在“201112AvgAmount”列中,它显示每个EmpID的不同值,而“200901AvgAmount”具有正确的值.

我的SQL脚本有什么问题吗?我在网上做了很多研究,但仍然找不到答案….

解决方法

您的脚本没有任何问题,这是SQL Server中分区的工作方式:/.如果将LAST_VALUE更改为MAX,则结果将相同.解决方案是:
SELECT A.EmpID,Last_Value(A.AverageAmount) OVER (PARTITION BY A.EmpID Order by A.DimYearMonthKey ROWS BETWEEN UNBOUNDED PRECEDING AND UNBOUNDED FOLLOWING) AS '201112AvgAmount'  
FROM  Emp_Amt  AS A

有一篇很棒的帖子,link. GL!

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读