码迷,mamicode.com
首页 > 数据库 > 详细

SQL Server ->> FIRST_VALUE和LAST_VALUE函数

时间:2016-01-30 02:19:59      阅读:266      评论:0      收藏:0      [点我收藏+]

标签:

两个都是SQL SERVER 2012引入的函数。用于返回在以分组和排序后取得最后一行的某个字段的值。很简单两个函数。ORDER BY字句是必须的,PARITION BY则是可选。

似乎没什么好说的。结果在测试LAST_VALUE函数的时候有个问题。

下面是测试脚本

;with t as (SELECT TOP 100 ROW_NUMBER() OVER(ORDER BY column_id) as num
FROM sys.columns)

select
num,
num/10 as grp_factor,
first_value(num) over(partition by num/10 order by num) as first_value,
last_value(num) over(partition by num/10 order by num) as last_value
from t

 

按照我的预测,0-9的FIRST_VALUE会返回1,而LAST_VALUE会返回9。然而情况却是FIRST_VALUE确实是返回1了。可是,LAST_VALUE却是返回了和本身NUM字段相同的值。没有弄明白怎么回事。似乎语句也没有问题。

技术分享

SQL Server ->> FIRST_VALUE和LAST_VALUE函数

标签:

原文地址:http://www.cnblogs.com/jenrrychen/p/5170337.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!