SqlServer基础系列——row_number() rank() dense_rank()SqlServer系列笔记
2016-11-13 01:38
471 查看
create table A
(
Id int identity,
Name char(10)
)
create table B
(
Id int,
[SubJect] char(10),
Score int
)
--1.查询各科成绩排名前二名的人的编号 No 姓名Name 科目Subject 分数Score
select * from (SELECT *,rn=ROW_NUMBER() OVER(PARTITION BY subject ORDER BY score desc)
FROM B) t where t.rn<=2
限制结果集。返回第3行到第5行的数据
( ROW_NUMBER 不能用在where子句中,所以将带行号的执行结果作为子查询,就可以将结果当成表一样用了):
SELECT * FROM
(
SELECT ROW_NUMBER() OVER(ORDER BY FSalary DESC) AS rownum,
FNumber,FName,FSalary,FAge FROM T_Employee
)
AS a
WHERE a.rownum>=3 AND a.rownum<=5
(
Id int identity,
Name char(10)
)
create table B
(
Id int,
[SubJect] char(10),
Score int
)
--1.查询各科成绩排名前二名的人的编号 No 姓名Name 科目Subject 分数Score
select * from (SELECT *,rn=ROW_NUMBER() OVER(PARTITION BY subject ORDER BY score desc)
FROM B) t where t.rn<=2
限制结果集。返回第3行到第5行的数据
( ROW_NUMBER 不能用在where子句中,所以将带行号的执行结果作为子查询,就可以将结果当成表一样用了):
SELECT * FROM
(
SELECT ROW_NUMBER() OVER(ORDER BY FSalary DESC) AS rownum,
FNumber,FName,FSalary,FAge FROM T_Employee
)
AS a
WHERE a.rownum>=3 AND a.rownum<=5
相关文章推荐
- oracle分析函数系列之rank,dense_rank,row_number:实现排名策略 .
- SQLServer针对排名函数ROWNUMBER()、RANK()、DENSE_RANK()、NTILE的研究!~
- [转]SqlServer四个排名函数(row_number、rank、dense_rank和ntile)的比较
- oracle分析函数系列之rank,dense_rank,row_number:实现排名策略
- SQLSERVER 2005的ROW_NUMBER、RANK、DENSE_RANK的用法
- SqlServer 排名函数(row_number、rank、dense_rank)的比较
- SQLServer 2005 实现排序报表的利器 排序函数RANK()、DENSE_RANK()、NTILE()和ROW_NUMBER()
- oracle分析函数系列之rank,dense_rank,row_number:实现排名策略
- hive笔记之row_number、rank、dense_rank
- SQLServer 2005 实现排序报表的利器 排序函数RANK()、DENSE_RANK()、NTILE()和ROW_NUMBER()
- SqlServer 排名函数(row_number、rank、dense_rank)的比较
- SqlServer四个排名函数(row_number、rank、dense_rank和ntile)的比较
- SQLServer 2005 实现排序报表的利器 排序函数RANK()、DENSE_RANK()、NTILE()和ROW_NUMBER()
- oracle笔记(5)----排序函数row_number、rank、dense_rank
- SQLServer 2005 实现排序报表的利器 排序函数RANK()、DENSE_RANK()、NTILE()和ROW_NUMBER()
- SQLSERVER排名函数RANK,DENSE_RANK,NTILE,ROW_NUMBER
- sqlserver 中row_number,rank,dense_rank,ntile排名函数的用法
- SqlServer四个排名函数(row_number、rank、dense_rank和ntile)的比较
- sqlserver 开窗函数over RANK(),DENSE_RANK(),ROW_NUMBER()三个排序的不同