SQL Server2005中四种排名函数的使用
2010-12-10 11:39
344 查看
排名函数是SQL Server2005新加的功能。在SQL Server2005中有如下四个排名函数:
下面依次介绍这四个排名函数的使用。这里我使用的是微软提供的实例数据库AdventureWorks。
一、 row_number
row_number函数的用途是非常广泛,这个函数的功能是为查询出来的每一行记录生成一个序号。row_number函数的用法如下面的SQL语句所示:
在sql server 2005的分析查询器中输入以下SQL语句。
根据上面的算法,如果记录总数为59,桶数为5,则前4个桶的记录数都是12,最后一个桶的记录数是11。
如果记录总数为53,桶数为5,则前3个桶的记录数为11,后2个桶的记录数为10。
1. row_number 2. rank 3. dense_rank 4. ntile |
一、 row_number
row_number函数的用途是非常广泛,这个函数的功能是为查询出来的每一行记录生成一个序号。row_number函数的用法如下面的SQL语句所示:
select row_number() over(order by field1) as row_number,* from t_table |
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]四、 ]在分析查询器中输入以下sql语句: [code] select ntile(4) over(order by OrderDate) as Rank,* from Sales.SalesOrderHeader select ntile(4) over(order by field1) as bucket,* from t_table
以上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 } |
如果记录总数为53,桶数为5,则前3个桶的记录数为11,后2个桶的记录数为10。
相关文章推荐
- SQL Server2005中四种排名函数的使用
- 在SQL Server2005中有如下四个排名函数:
- SQL 语句技巧--排名函数的使用实例
- SQL SERVER2005 RowNumber() 函数使用(转载)
- 关于数据库排名函数的使用
- 在SQL Server2005中有如下四个排名函数:
- SQL Server2005中的排名函数
- 销量排名,使用临时表,不使用函数和变量情况下的实现
- Sql Server2005 Transact-SQL 新兵器学习总结之-排名函数 转
- 使用Sql Server2005中新添加的row_number()和rank()返回行号或排名
- oracle排名函数的使用方法分享
- Sql Server2005 4个排名函数: RANK(),DENSE_RANK(),ROW_NUMBER(),NTILE()
- Sql Server2005对t-sql的增强之排名函数ROW_NUMBER, RANK, DENSE_RANK, NTILE
- Sql Server2005 Transact-SQL 新兵器学习总结之-排名函数 <转>
- SQL Server2005中有如下四个排名函数
- Sqlserver使用排名函数Row_Number()函数查询指定范围的数据
- Sql Server2005 Transact-SQL 新兵器学习总结之-排名函数
- SQL Server2005 四个排名函数(row_number、rank、dense_rank和ntile)的比较
- [导入]Sql Server2005对t-sql的增强之排名函数
- SQL Server2005排名函数