Teradata SQL用法之排名和分页

1. 选取排序后的前N条记录 
Sql代码 
  1. select top 3 e_name from ptemp.cuishen_temp_20100707  
  2. order by id  

Sql代码
  1. select top 3 * from ptemp.cuishen_temp_20100707  
  2. order by id  
2. 用rank给记录排名 

默认是降序排名 
Sql代码
  1. select rank(e_name), id, e_name from ptemp.cuishen_temp_20100707_2  
  2. qualify rank(e_name) <> 2 
也可以指定asc关键字进行升序排名 
Sql代码
  1. select rank(e_name asc), id, e_name from ptemp.cuishen_temp_20100707_2  
  2. qualify rank(e_name asc) <= 2  


其中 
Sql代码
  1. qualify rank(e_name asc) <= 2  
子句表示对结果集进行限制,选取e_name字段升序排名前2的记录 
限定条件当然也可以这样写: 
Sql代码
  1. select rank(name asc), id, name from ptemp.cuishen_temp_20100707  
  2. qualify rank(name asc) >= 2 and rank(name asc) <= 5  
3. 分页查询 

可以用row_number关键字来进行分页查询,例如: 
Sql代码
  1. select * from ptemp.cuishen_temp_20100707  
  2. qualify row_number() over(order by id) >= 2 and row_number() over(order by id) <= 5  
4. row_number和rank的区别 

row_number:顾名思意,就是行号,不管记录相不相同,行号都是不同的。 
rank:对于不同的记录排名当然是不同的,而对于相同的记录排名是相同的,这就是为什么分页查询不用rank来做的原因。 

5. 可以用PARTITION BY关键字进行去重排名查询 
Sql代码
  1. select * from ptemp.cuishen_temp_20100707  
  2. QUALIFY ROW_NUMBER() OVER(PARTITION BY id ORDER BY id) = 1  
上句表示:按id字段排序,取每段重复id记录的TOP 1。千万注意:这个不能用rank来做。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值