博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
oracle与mysql与sqlserver的分页
阅读量:6259 次
发布时间:2019-06-22

本文共 2386 字,大约阅读时间需要 7 分钟。

 假设当前是第PageNo页,每页有PageSize条记录,现在分别用Mysql、Oracle和SQL Server分页查询student表。

1、Mysql的分页查询: 

1 SELECT2     *3 FROM4     student5 LIMIT (PageNo - 1) * PageSize,PageSize;

理解:(Limit n,m)  =>从第n行开始取m条记录,n从0开始算。

2、Oracel的分页查询:

1 SELECT 2     * 3 FROM 4     ( 5         SELECT 6             ROWNUM rn ,* 7         FROM 8             student 9         WHERE10             Rownum <= pageNo * pageSize11     )12 WHERE13     rn > (pageNo - 1) * pageSize

理解:假设pageNo = 1,pageSize = 10,先从student表取出行号小于等于10的记录,然后再从这些记录取出rn大于0的记录,从而达到分页目的。ROWNUM从1开始。

3、SQL Server分页查询:

1 SELECT 2     TOP PageSize * 3 FROM 4     ( 5         SELECT 6             ROW_NUMBER () OVER (ORDER BY id ASC) RowNumber ,* 7         FROM 8             student 9     ) A10 WHERE11     A.RowNumber > (PageNo - 1) * PageSize

 理解:假设pageNo = 1,pageSize = 10,先按照student表的id升序排序,rownumber作为行号,然后再取出从第1行开始的10条记录。

  分页查询有的数据库可能有几种方式,这里写的可能也不是效率最高的查询方式,但这是我用的最顺手的分页查询,如果有兴趣也可以对其他的分页查询的方式研究一下。

 

另一篇博文:

1、用limit分页

/*

* sql:可以是单表的查询语句,也可以是多表的联合查询语句

* firstIndex:其实的索引

* pageSize:每页显示的记录数

*/

select o.* from (sql) o limit firstIndex,pageSize

 

eg:  select * from (select * from Student)  limit 0,20;    //取1-20条数据

        select * from (select * from Student)  limit 20,20;    //取21-40条数据

 

第二种 写法

select * from Student  where limit (currentPage-1)*pageSize ,pageSize;

 

 

2、用ROWNUM分页

/*

* firstIndex:起始索引

* pageSize:每页显示的数量

* sql:可以是简单的单表查询语句,也可以是复杂的多表联合查询语句

*/

select * from(select a.*,ROWNUM rn from(sql) a where ROWNUM<=(firstIndex+pageSize)) where rn>firstIndex

 

 

eg:    select * from(select a.*,ROWNUM rn from(select * from Student order by id asc) a where ROWNUM<=20) where rn>0   // 取1-20条数据

          select * from(select a.*,ROWNUM rn from(select * from Student order by id asc) a where ROWNUM<=(20+20)) where rn>20   // 取21-40条数据

第二种写法

select * from ( select rownum rn,t.* from Student  t where rownum <= currentPage*pageSize ) where rownum > (currentPage -1)*pageSize;

 

 

3、SqlServer用top分页

/*

* firstIndex:起始索引

* pageSize:每页显示的数量

* orderColumn:排序的字段名

* sql:可以是简单的单表查询语句,也可以是复杂的多表联合查询语句

*/

select top pageSize o.* from (select row_number() over(order by orderColumn) as rownumber,* from(sql)) as o where rownumber>firstIndex;

 

eg:      select top 20 o.* from (select row_number() over(order by id asc) as rownumber,* from(select * from Student)) as o where rownumber>0;   // 取1-20条数据

        

第二种写法

select top  pageSize  * from Student  where id not in (select top (currentPage-1)*pageSize  id from Student) ;

转载地址:http://hhtsa.baihongyu.com/

你可能感兴趣的文章
【数据库】主键、外键、索引
查看>>
C#解析HTML
查看>>
导出/打印项目数据报表需要设置IE浏览器
查看>>
8个强大的基于Bootstrap的CSS框架
查看>>
MAC OSX在视图port哪个程序占用,杀死进程的方法
查看>>
Linux中select poll和epoll的区别
查看>>
图像识别引擎-引擎收集知识地图~
查看>>
【面试】如何找到迷宫出口
查看>>
iscroll5实现下拉加载更多
查看>>
hdu1753()模拟大型实景数字相加
查看>>
Cocos2d-x之MenuItem
查看>>
Esper学习之六:EPL语法(二)
查看>>
流和文件
查看>>
iOS:UIMapView地图视图控件的简单使用
查看>>
关于Python的3张图
查看>>
作IFRAME于iOS您的设备上支持滚动
查看>>
后台数据库优化——板机
查看>>
C++ redirect input
查看>>
linux_sound_alsa_Android+alsa音频系统中的几个问题
查看>>
IOS Core Image之二
查看>>