Teradata SQL用法之排名和分页
2013-05-22 10:12
281 查看
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
2. 用rank给记录排名
默认是降序排名
Sql代码
select rank(e_name), id, e_name from ptemp.cuishen_temp_20100707_2
qualify rank(e_name) <> 2
也可以指定asc关键字进行升序排名
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
子句表示对结果集进行限制,选取e_name字段升序排名前2的记录
限定条件当然也可以这样写:
Sql代码
select rank(name asc), id, name from ptemp.cuishen_temp_20100707
qualify rank(name asc) >= 2 and rank(name asc) <= 5
3. 分页查询
可以用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
4. row_number和rank的区别
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
上句表示:按id字段排序,取每段重复id记录的TOP 1。千万注意:这个不能用rank来做。
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
2. 用rank给记录排名
默认是降序排名
Sql代码
select rank(e_name), id, e_name from ptemp.cuishen_temp_20100707_2
qualify rank(e_name) <> 2
也可以指定asc关键字进行升序排名
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
子句表示对结果集进行限制,选取e_name字段升序排名前2的记录
限定条件当然也可以这样写:
Sql代码
select rank(name asc), id, name from ptemp.cuishen_temp_20100707
qualify rank(name asc) >= 2 and rank(name asc) <= 5
3. 分页查询
可以用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
4. row_number和rank的区别
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
上句表示:按id字段排序,取每段重复id记录的TOP 1。千万注意:这个不能用rank来做。
相关文章推荐
- springdatajpa nativeSQL的分页用法和注意事项以及解决防范
- SqlDataReader读取分页数据,pageCount你是肿么了?
- SQL segments in Teradata
- sqlDataAdapter的FillSchema用法
- SqlDataReader 用法(C#)
- SqlDataAdapter用法
- ADO.NET 2SqlDataAdapter、DataSet 的基本用法
- SqlDataReader 的用法
- 关于DataSet事务处理以及SqlDataAdapter四种用法
- SqlDataAdapter 用法详解
- ado:SqlDataAdapter,dataset 与SqlDataReader的用法一
- C#里sqlDataAdapter.fill(DataSet,String)的用法
- SqlDataAdapter.TableMappings 的用法
- SqlConnection,SqlCommand,SqldataReader的用法总结
- 分页解决方案 —— GridView + QuickPager + QuickPager_SQL + DataAccessLibrary + 数据库
- 关于DataSet事务处理以及SqlDataAdapter四种用法
- SqlConnection,SqlCommand,SqldataReader的用法总结:
- C#里sqlDataAdapter.fill(DataSet,String)的用法
- [转载]SqlConnection,SqlCommand,SqldataReader的用法总结:
- SqlConnection,SqlCommand,SqldataReader的用法总结