1. 选取排序后的前N条记录
Sql代码
- select top 3 e_name from ptemp.cuishen_temp_20100707
- order by id
Sql代码
- select top 3 * from ptemp.cuishen_temp_20100707
- order by id
默认是降序排名
Sql代码
- select rank(e_name), id, e_name from ptemp.cuishen_temp_20100707_2
- qualify rank(e_name) <> 2
Sql代码
- select rank(e_name asc), id, e_name from ptemp.cuishen_temp_20100707_2
- qualify rank(e_name asc) <= 2
其中
Sql代码
- qualify rank(e_name asc) <= 2
限定条件当然也可以这样写:
Sql代码
- select rank(name asc), id, name from ptemp.cuishen_temp_20100707
- qualify rank(name asc) >= 2 and rank(name asc) <= 5
可以用row_number关键字来进行分页查询,例如:
Sql代码
- select * from ptemp.cuishen_temp_20100707
- qualify row_number() over(order by id) >= 2 and row_number() over(order by id) <= 5
row_number:顾名思意,就是行号,不管记录相不相同,行号都是不同的。
rank:对于不同的记录排名当然是不同的,而对于相同的记录排名是相同的,这就是为什么分页查询不用rank来做的原因。
5. 可以用PARTITION BY关键字进行去重排名查询
Sql代码
- select * from ptemp.cuishen_temp_20100707
- QUALIFY ROW_NUMBER() OVER(PARTITION BY id ORDER BY id) = 1