分页查询这个内容基本上是个项目都会用的到的东西,面试也会问到的,
平常项目中老是百度用法,这些写博客来总结一下,省的老是百度。
现在主流的关系型数据的分页实现还是有点差别的,以oracle、mysql、server为例。
oracle分页
数据采用是oracle安装时勾选的事例表,有emp,dept、SALGRADE等数据表。
emp数据表的内容
oracle实现分页的方式是行号ROWNUM+FROM子查询,要实现分页需要知道两个参数:
currentPage 表示当前页
linesize 表示显示的数据量
示例一
查询第一页数据,每页显示三条数据
currentPage=1 linesize =3:从数据表中取出1~3条数据
SELECT * FROM (SELECT ROWNUM rn,EMPNO,ENAME,JOB,SAL,HIREDATE,MGR,COMM,DEPTNO
FROM EMP WHERE ROWNUM<=3) temp
WHERE temp.rn>=1;
结果:
<