分页在项目中经常用到。SQL中没有”上一页“、“下一页”的概念,所以必须要对处理的行按照某种方式排序,才能精确返回想要的结果。
首先介绍一下row_number() over(partition by col1 order by col2),先根据col1分组,在分组内部再根据col2排序;得到的结果值就表示每组内部排序后的顺序编号(从1开始递增)。
对于DB2、Oracle和SQL Server使用窗口函数row_number() over,据此排序,而且能够在where子句中指定要返回的窗口记录:
select sal from(
select
row_number() over(order by sal) as rn, sal from emp ) x where rn between 1 and 5本例返回1~5行。只需修改where子句,就能返回所需的行。
对于MySQL,由于其支持LIMIT和OFFSET子句;可以使用LIMIT指定返回的行数,使用OFFSET指定要跳过的行数,指定OFFSET为0表示从第1行开始,指定OFFSET为5表示从第6行开始。
例如按工资顺序返回前五行:
select sal from emp order by sal limit 5 offset 0