`
chenhongquan
  • 浏览: 45007 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

SQL server 2005新增的几个函数 转

阅读更多

SQL server 2005新增的几个函数,分别是row_number( )、rank( )、,DENSE_RANK( )、ntile( )下面以实例分别简单讲解。

1.row_number( )
         先来点数据,先建个表

SET NOCOUNT ON
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')
直接用例子说明问题:
SELECT ROW_NUMBER() OVER (ORDER BY Age) AS [Row Number by Age],
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 Ageselect * from #Adrop table #a如果不想按年龄排序,可以这样写SELECT ROW_NUMBER() OVER (ORDER BY (SELECT 1)) AS [Row Number by Record Set],
FirstName,
Age
FROM Person另外一个例子SELECT ROW_NUMBER() 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                  F
2                           Mary              11                 F
3                           Sherry            11                 F
4                           Sue               29                 F
1                           Larry             5                  M
2                           George            6                  M
3                           Sam               17                 M
4                           Ted               23                 M
5                           Marty             23                 M
6                           Frank             38                 M
7                           John              40                 M注意,姓名M开始,序号又从1,2,3开始了

 2.RANK( )函数         先看例子SELECT RANK() OVER (ORDER BY Age) AS [Rank by Age],
FirstName,
Age
FROM Person输出如下:Rank by Age                 FirstName         Age
-------------------- ---------- -----------
1                           Larry             5
2                           Doris             6
2                           George            6
4                           Mary              11
4                           Sherry            11
6                           Sam               17
7                           Ted               23
7                           Marty             23
9                           Sue               29
10                          Frank             38
11                          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                  F
2                           Mary              11                 F
2                           Sherry            11                 F
4                           Sue               29                 F
1                           Larry             5                  M
2                           George            6                  M
3                           Sam               17                 M
4                           Ted               23                 M
4                           Marty             23                 M
6                           Frank             38                 M
7                           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段


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/htl258/archive/2009/03/20/4006717.aspx

分享到:
评论

相关推荐

    SQL SERVER 2005 新增的几个小功能

    ### SQL Server 2005新增的小功能详解 #### 一、分页查询数据 在SQL Server 2005之前,实现分页查询通常较为复杂且效率不高。随着SQL Server 2005的发布,引入了一种更为简便的方式来实现分页查询,即通过`ROW_...

    SQL SERVER 2005 简介

    SQL Server 2005 是一个全新的数据库平台系统,包含多种软件元件与服务,来满足企业对于日渐复杂的数据系统的需求。该版本的T-SQL结构化查询语言大幅扩增了新的查询指令,例如XQuery、取得排名顺序的函数、集合运算...

    Microsoft SQL Server 2005技术内幕: T-SQ程序设计.pdf

    该书解释并比较了SQL Server 2000和SQL Server 2005在数据库开发相关问题上的解决方案,深入讨论了SQL Server 2005中新增的T-SQL编程特性,包含了大量的代码示例、表示例和逻辑难题以帮助数据库开发人员和管理员理解...

    SQL Server 2005 T-SQL增强

    在SQL Server 2005中,新增了以下几种排名函数: - **ROW_NUMBER**: 为结果集中的每一行分配一个唯一的整数。 - **RANK**: 根据特定列的值对行进行排序并分配一个排名。 - **DENSE_RANK**: 类似于RANK函数,但在...

    SQL Server 2005技术内幕英文版CHM文件2

    在SQL Server 2005中,有几个重要的知识点值得我们深入学习: 1. **Transact-SQL (T-SQL)增强**:SQL Server 2005对T-SQL进行了大量改进,包括新函数、新语句和优化的执行计划。例如,新增了窗口函数,使得在复杂的...

    SQL Server 2005 T-SQL增强_PDF

    在SQL Server 2005中,T-SQL得到了显著的增强,主要体现在以下几个方面: 1. **新函数和运算符**:SQL Server 2005引入了许多新函数,如窗口函数(ROW_NUMBER(), RANK(), DENSE_RANK()等),这些函数允许在结果集中...

    SQL server 2005下载地址(大家可以看看)

    根据提供的文件信息,我们可以从中提炼出与SQL Server 2005相关的几个关键知识点: ### SQL Server 2005简介 SQL Server 2005是微软公司发布的一款关系型数据库管理系统,它继承和发展了SQL Server 2000的强大功能...

    SQL Server的升级之路系列课程(3):从MSDE 2000升级到SQL Server 2005工作组版.rar

    总的来说,从MSDE 2000升级到SQL Server 2005工作组版是一个复杂但必要的过程,能够为企业带来更好的性能、更强的功能和更高的安全性。在这个过程中,深入理解和掌握SQL Server的新特性以及升级的最佳实践至关重要。...

    SQLServer利用SSIS包定时同步新增数据到其它库

    在深入了解具体操作之前,我们需要了解以下几个基础概念: - **SSIS (SQL Server Integration Services)**:是 Microsoft SQL Server 平台的一部分,主要用于数据迁移、转换和加载任务。 - **包 (Package)**:SSIS ...

    SQL SERVER 2012新增函数之逻辑函数IIF

    这个函数在VB(Visual Basic)或ACCESS等环境中已经存在,但在SQL Server 2012以前的版本中并未直接支持。 IIF函数的基本语法结构如下: ```sql iif(布尔表达式, value1, value2) ``` 这里的`布尔表达式`是一个...

    通过SQL_Server_2005索引视图提高性能

    #### 七、SQL Server 2005的索引视图新增功能 SQL Server 2005在索引视图功能上进行了多方面的增强,包括但不限于: 1. **更灵活的索引设计**:提供了更多选项用于创建和管理索引视图。 2. **改进的性能监控工具**...

    发挥SQL Server 2005的新功能——两个新特性带来许多好处,但需要较大改动.pdf

    SQLCLR是SQL Server 2005中一个关键的特性,它允许数据库管理员和开发人员使用.NET Framework的编程语言(比如C#和***)编写存储过程、函数、触发器等数据库对象。这样的改变带来了几个好处: - 性能提升:CLR存储...

    SQL SEVER 2005 读书笔记

    **SQL Server 2005** 的架构主要包括以下几个部分: 1. **数据库引擎**:这是 SQL Server 的核心组件,负责处理数据存储、查询执行等操作。 2. **Analysis Services**:用于提供多维数据分析和数据挖掘功能。 3. **...

    SQL SERVER 2012新增函数之字符串函数FORMAT详解

    这个函数的引入极大地扩展了SQL Server在数据表示上的灵活性,使得数据库查询结果更加符合用户界面的显示需求。 FORMAT函数的基本语法结构如下: ```sql FORMAT(value, format, culture) ``` 其中: - `value`:...

    SQL自定义函数的好处

    SQL自定义函数是SQL Server 2000中新增的数据库对象,它允许用户根据需要自定义函数,以满足特定的业务需求。与系统内置的函数不同,自定义函数可以根据用户的需求进行定制,满足特定的业务需求。 SQL自定义函数的...

    SQL2005工作经验

    case在where条件中的应用; SQL注入;... SQL 2005新增的几个函数之学习; 多数据库查询; 利用NEWID函数来取随机记录; 利用ROW_NUMBER方法分页; 在数据库中处理字符串数组; ......

    SQL Server学习总结.docx

    主要包括以下几个部分: - **对象资源管理器**:用于浏览服务器、数据库、表等数据库对象。 - **查询编辑器**:编写和执行SQL查询的主要区域。 - **消息和结果面板**:显示查询执行的结果以及任何错误或警告信息...

    SQLServer中XML应用

    最新的 SQL Server 2008,在继承了前几个版本的基础上,进行了大量的优化和改进。它不仅支持定义 XML 数据类型的变量和参数,还能创建处理 XML 类型数据的视图和触发器。更重要的是,SQL Server 2008 支持使用 ...

    Sql批量操作数据

    3. **技术方案三:** 使用SQL Server 2008新增的特性——表值参数(Table-Valued Parameter)。这种方法适用于插入数据量较少的情况(一般少于1000行)。 4. **技术方案四:** 对于单列字段,可以将要插入的数据...

Global site tag (gtag.js) - Google Analytics