SQL Server 2005新增函数简介
来源:互联网 发布:tomcat mac 编辑:程序博客网 时间:2024/04/28 11:12
1.row_number( )
先来点数据,先建个表
CREATE TABLE Person(
FirstName VARCHAR(10),
Age INT,
Gender CHAR(1))
INSERT INTO Person VALUES ('Ted',23,'M')
INSERT INTO Person VALUES ('John',40,'M')
INSERT INTO Person VALUES ('George',6,'M')
INSERT INTO Person VALUES ('Mary',11,'F')
INSERT INTO Person VALUES ('Sam',17,'M')
INSERT INTO Person VALUES ('Doris',6,'F')
INSERT INTO Person VALUES ('Frank',38,'M')
INSERT INTO Person VALUES ('Larry',5,'M')
INSERT INTO Person VALUES ('Sue',29,'F')
INSERT INTO Person VALUES ('Sherry',11,'F')
INSERT INTO Person VALUES ('Marty',23,'F')
FirstName,
Age
FROM Person
出现的数据如下
Row Number by Age FirstName Age
-------------------------- ---------- --------
1 Larry 5
2 Doris 6
3 George 6
4 Mary 11
5 Sherry 11
6 Sam 17
7 Ted 23
8 Marty 23
9 Sue 29
10 Frank 38
11 John 40
可以观察到,是根据年龄升序排列了,并且row_number()是给出了序列号了,这个序列号被重命名为Row Number by Age,
与sql server2000对比:
如果在sql server2000中实现相对麻烦一些,我们可以利用IDENTITY()函数实现,但IDENTITY()函数只能用在sql server2000临时表中,因此需要将数据检索到临时表里。
select identity(int,1,1) as [Row Number by Age],FirstName,Age into #A from Person order by Age
select * from #A
drop table #a
如果不想按年龄排序,可以这样写
SELECT ROW_NUMBER() OVER (ORDER BY (SELECT 1)) AS [Row Number by Record Set],FirstName,AgeFROM Person
另外一个例子
SELECT ROW_NUMBER() OVER (PARTITION BY Gender ORDER BY Age) AS [Partition by Gender],FirstName,Age,GenderFROM Person
Partition by Gender FirstName Age Gender-------------------- ---------- ----------- ------1 Doris 6 F2 Mary 11 F3 Sherry 11 F4 Sue 29 F1 Larry 5 M2 George 6 M3 Sam 17 M4 Ted 23 M5 Marty 23 M6 Frank 38 M7 John 40 M注意,姓名M开始,序号又从1,2,3开始了
2.RANK( )函数
先看例子
SELECT RANK() OVER (ORDER BY Age) AS [Rank by Age],FirstName,AgeFROM Person
输出如下:
Rank by Age FirstName Age-------------------- ---------- -----------1 Larry 52 Doris 62 George 64 Mary 114 Sherry 116 Sam 177 Ted 237 Marty 239 Sue 2910 Frank 3811 John 40
看到了么,同年岭的话,将有相同的顺序,顺序成1,2,2,4了。
与sql server2000对比:
出现了RANK()函数实在是方便,在sql server2000里实现排序并列的问题麻烦很多。
select [Rank by Age]=isnull((select count(*) from person where Age>A.Age),0)+1,FirstName,Age from Person A order by [Rank by Age]
SELECT RANK() OVER(PARTITION BY Gender ORDER BY Age) AS [Partition by Gender],
FirstName, Age, Gender FROM Person输出为
Partition by Gender FirstName Age Gender-------------------- ---------- ----------- ------1 Doris 6 F2 Mary 11 F2 Sherry 11 F4 Sue 29 F1 Larry 5 M2 George 6 M3 Sam 17 M4 Ted 23 M4 Marty 23 M6 Frank 38 M7 John 40 M
可以看到,按性别分组了,每个性别分组里,继续是用了rank( )函数
3.DENSE_RANK( )函数
SELECT DENSE_RANK() OVER (ORDER BY Age) AS [Dense Rank by Age],
FirstName,
Age
FROM Person
输出结果为:
Dense Rank by Age FirstName Age
-------------------- ---------- -----------
1 Larry 5
2 Doris 6
2 George 6
3 Mary 11
3 Sherry 11
4 Sam 17
5 Ted 23
5 Marty 23
6 Sue 29
7 Frank 38
8 John 40
看到了么,和rank函数区别是,顺序始终是连续的,Doris 和George同年,都是排第2位,但之后的mary不象rank函数那样排第4,而是排第3位了
4.ntile( )函数
SELECT FirstName,
Age,
NTILE(3) OVER (ORDER BY Age) AS [Age Groups]
FROM Person
输出结果:
FirstName Age Age Groups
---------- ----------- --------------------
Larry 5 1
Doris 6 1
George 6 1
Mary 11 1
Sherry 11 2
Sam 17 2
Ted 23 2
Marty 23 2
Sue 29 3
Frank 38 3
John 40 3
这个函数按照ntile(n)中的N,把记录强制分成多少段,11条记录现在分成3段了,lary到mary是第1段,sherry到maty是第2段,sue到john是第3段了。
- SQL Server 2005新增函数简介
- SQL server 2005中新增的排序函数及操作
- SQL server 2005中新增函数及操作
- SQL SERVER 2005 新增的几个常用的函数
- SQL server 2005中新增函数及操作
- SQL Server 2005中新增的功能强大的窗口函数
- SQL Server 2005 新增功能
- SQL Server 2005 新增功能
- SQL SERVER 2005 新增语法
- 新增系统日志函数(SQL Server)
- SQL Server 2012新增内置函数
- SQL Server 2012 2016 2017 新增函数
- SQL SERVER 开窗函数简介
- SQL SERVER 开窗函数简介
- SQL SERVER 2012 T-SQL新增聚合函数
- SQL Server 2005新增的功能
- SQL Server 2005 的新增功能
- SQL Server 2005 SP3 中的新增功能
- 美国FCC支持建立全国性免费无线互联网网络
- Mozilla下周将推手机版火狐浏览器"Fennec"
- Java EE 进行开发已经变得困难
- [双语阅读]日本:开心草写博客 记录“绿色心情”
- 2008-10-23
- SQL Server 2005新增函数简介
- 幸福的味道
- TCPMP超级播放器Windows CE5.0(ARMV4)编译方法
- 2008.10.23 大风降温
- nmea pdf
- aaaaaaaaaaaaaaaaaaaaaaaaa
- 恭喜您获得“百度有啊”的邀请访问权限
- java面试题
- 在项目开发中对数据分时统计的一个SQL