[MSSQL2012]First_Value函数

First_Value返回结果集中某列第一条数据的值,跟TOP 1效果一样,比较简单的一个函数

先贴测试用代码

DECLARE @TestData TABLE(
    ID INT IDENTITY(1,1),
    Department VARCHAR(20),
    LastName VARCHAR(20),
    Rate FLOAT
)
INSERT INTO @TestData(Department,LastName,Rate)
SELECT ‘Document Control‘,‘Arifin‘,17.7885 UNION ALL
SELECT ‘Document Control‘,‘Norred‘,16.8269 UNION ALL
SELECT ‘Document Control‘,‘Kharatishvili‘,16.8269 UNION ALL
SELECT ‘Information Services‘,‘Chai‘,10.25 UNION ALL
SELECT ‘Information Services‘,‘Berge‘,10.25 UNION ALL
SELECT ‘Information Services‘,‘Trenary‘,50.4808 UNION ALL
SELECT ‘Information Services‘,‘Conroy‘,39.6635 UNION ALL
SELECT ‘Information Services‘,‘Ajenstat‘,38.4615 UNION ALL
SELECT ‘Information Services‘,‘Wilson‘,38.4615 UNION ALL
SELECT ‘Information Services‘,‘Connelly‘,32.4519 UNION ALL
SELECT ‘Information Services‘,‘Meyyappan‘,32.4519

SELECT * FROM @TestData

 

下边使用FIRST_VALUE函数,创建一列新列,返回结果集中第一行的LastName值,这个所谓的第一行受OVER里的ORDER BY影响,看图和代码:

以ID正序取

 

以ID倒序取

 

如果SQL脚本中使用了PARTITION分区函数,则FIRST_VALUE返回每个分区内的首条数据值,看演示

这里以Department分区,则整个数据集被分成了两部分:Information Services和Document Control两块,这时FIRST_VALUE分别返回两块分区内的首条数据值,同样的受ORDER BY关键字的影响,

 

再看一个受ORDER BY 影响的例子

 

The End

时间: 2024-10-11 14:44:15

[MSSQL2012]First_Value函数的相关文章

[MSSQL2012]CUME_DIST函数

CUME_DIST函数以某列作为基准,计算其它行相对于基准行数据的比例.差距比例,比较容易理解 先看下测试数据 DECLARE @TestData TABLE(     ID INT IDENTITY(1,1),     Department VARCHAR(20),     LastName VARCHAR(20),     Rate FLOAT ) INSERT INTO @TestData(Department,LastName,Rate) SELECT 'Document Control

[MSSQL2012]LEAD函数

LEAD函数简单点说,就是把下一行的某列数据提取到当前行来显示,看示例更能解释清楚,先看测试用脚本 DECLARE @TestData TABLE(     ID INT IDENTITY(1,1),     Department VARCHAR(20),     LastName VARCHAR(20),     Rate FLOAT ) INSERT INTO @TestData(Department,LastName,Rate) SELECT 'Document Control','Ari

锋利的SQL2014:基于窗口的偏移计算

SQL Server 2012引入了四个偏移函数:LAG和LEAD.FIRST_VALUE和LAST_VALUE,用于从当前行的某个偏移量.或是一个窗口框架的开头或结尾的行返回一个元素. LAG和LEAD支持窗口分区和窗口排序子句,FIRST_VALUE和LAST_VALUE在支持窗口分区和窗口排序子句的基础上,还支持窗口框架子句. 9.5.1 LAG和LEAD函数 LAG函数用于在当前行之前查找,LEAD函数在之后查找.函数的第一个参数(必选)指定要返回值的列,第二个参数(可选)是偏移量(如果

Oracle 10gR2分析函数

Oracle 10gR2分析函数汇总 (Translated By caizhuoyi 2008‐9‐19) 说明:  1. 原文中底色为黄的部分翻译存在商榷之处,请大家踊跃提意见:  2. 原文中淡蓝色字体的文字,不宜翻译,保持原样.  1. ANALYTIC FUNCTIONS Analytic functions compute an aggregate value based on a group of rows. They differ from aggregate functions

postgresql整理

数据类型: 整型:  smallint integer bigint 任意精度数值:  numeric(precision,scale)  精度.刻度 浮点型:  real 序号类型(自增): serial  bigserial 字符类型:varchar(n)  char(n) text 日期类型:timestamp8字节  2013-05-17 13:01:38.437925 Interval  12字节  555283:40:10 date      4字节 2013-05-17 time 

SQL Server ->> FIRST_VALUE和LAST_VALUE函数

两个都是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_

Hive函数:LAG,LEAD,FIRST_VALUE,LAST_VALUE

参考自大数据田地:http://lxw1234.com/archives/2015/04/190.htm 测试数据准备: create external table test_data ( cookieid string, createtime string, --页面访问时间 url string --被访问页面 ) ROW FORMAT DELIMITED FIELDS TERMINATED BY ',' stored as textfile location '/user/jc_rc_ft

浅谈DB2在线分析处理函数

最近碰到一个测试需求,使用到了在线分析处理(OLAP),现总结记录一下,也希望能帮到有相关问题的朋友. 1. 测试环境是DB2,通过ETL(数据抽取,数据转换,数据加载)技术将数据源数据加载到目标数据仓库. 2. 需求大概意思:验证能否将包含制定商品编码的订单从数据源加载到目标数据库. 3. 目标数据来源于7个不同的应用数据库,每个应用数据库都存储商品编码组相应的订单,其中的50个商品编码相关的订单需要加载到目标仓库. 分析需求后我们得到测试的方法: 1. 在源数据库查询样本订单数据,取得其中所

over partition by 函数

over(Partition by...) 一个超级牛皮的ORACLE特有函数. 天天都用ORACLE,用了快2年了.最近才接触到这个功能强大而灵活的函数.真实惭愧啊! oracle的分析函数over 及开窗函数 一:分析函数over Oracle从8.1.6开始提供分析函数,分析函数用于计算基于组的某种聚合值,它和聚合函数的不同之处是 对于每个组返回多行,而聚合函数对于每个组只返回一行. 下面通过几个例子来说明其应用. 1:统计某商店的营业额. date       sale 1