您的位置:首页 > 数据库

SQL Server2005中四种排名函数的使用

2010-12-10 11:39 344 查看
排名函数是SQL Server2005新加的功能。在SQL Server2005中有如下四个排名函数:

  1. row_number
  2. rank
  3. dense_rank
  4. ntile

下面依次介绍这四个排名函数的使用。这里我使用的是微软提供的实例数据库AdventureWorks。

一、 row_number

 row_number函数的用途是非常广泛,这个函数的功能是为查询出来的每一行记录生成一个序号。row_number函数的用法如下面的SQL语句所示:

  select row_number() over(order by field1) as row_number,* from t_table

在sql server 2005的分析查询器中输入以下SQL语句。

 select row_number() over(order by OrderDate) as Rownumber,*
from Sales.SalesOrderHeader
order by SalesOrderID Desc


执行结果如下:(省略部分列)



Rownumber列并没有因为SalesOrderID的排序发生值的变化。

我们可以使用row_number()函数来实现查询表中指定范围的记录,一般将其应用到Web应用程序的分页功能上。下面我们查询Rownumber在1到10之间的数据,SQL语句如下:


执行结果如下:



 ]
[code]   select rank() over(order by OrderDate) as Rank,*
from Sales.SalesOrderHeader


执行结果如下:



对于OrderDate相同的字段,rank列的值也是相同的。

三、 dense_rank

dense_rank函数的功能与rank函数类似,只是在生成序号时是连续的,而rank函数生成的序号有可能不连续。如上面的例子中如果rank列有19个1,那下一条记录就是从20开始了。用法如下面的SQL语句所示:


[b]四、 ]

 select ntile(4) over(order by field1) as bucket,* from t_table

在分析查询器中输入以下sql语句:

[code] select ntile(4) over(order by OrderDate) as Rank,*
from Sales.SalesOrderHeader


以上SQL语句的结果把dense_rank()函数生成的结果放在4个桶中,也就是分成四组。

也许你会问这么一个问题,SQL Server2005怎么来决定某一桶应该放多少记录呢?可能t_table表中的记录数有些少,那么我们假设t_table表中有59条记录,而桶数是5,那么每一桶应放多少记录呢?

  实际上通过两个约定就可以产生一个算法来决定哪一个桶应放多少记录,这两个约定如下:

  1. 编号小的桶放的记录不能小于编号大的桶。也就是说,第1捅中的记录数只能大于等于第2桶及以后的各桶中的记录。

  2. 所有桶中的记录要么都相同,要么从某一个记录较少的桶开始后面所有捅的记录数都与该桶的记录数相同。也就是说,如果有个桶,前三桶的记录数都是10,而第4捅的记录数是6,那么第5桶和第6桶的记录数也必须是6。

  根据上面的两个约定,可以得出如下的算法:

 

// mod表示取余,div表示取整
  if(记录总数 mod 桶数 == 0)
  {
  recordCount = 记录总数 div 桶数;
  将每桶的记录数都设为recordCount
  }
  else
  {
  recordCount1 = 记录总数 div 桶数 + 1;
  int n = 1; // n表示桶中记录数为recordCount1的最大桶数
  m = recordCount1 * n;
  while(((记录总数 - m) mod (桶数 - n)) != 0 )
  {
  n++;
  m = recordCount1 * n;
  }
  recordCount2 = (记录总数 - m) div (桶数 - n);
  将前n个桶的记录数设为recordCount1
  将n + 1个至后面所有桶的记录数设为recordCount2
  }



  根据上面的算法,如果记录总数为59,桶数为5,则前4个桶的记录数都是12,最后一个桶的记录数是11。

  如果记录总数为53,桶数为5,则前3个桶的记录数为11,后2个桶的记录数为10。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: