Oracle、DB2、SQLSERVER、Mysql、Access分页SQL语句梳理
最近把平时在项目中常用到的数据库分页sql总结了下。大家可以贴出分页更高效的sql语句。
sqlserver分页
第一种分页方法
需用到的参数:
pageSize 每页显示多少条数据
pageNumber 页数 从客户端传来
totalRecouds 表中的总记录数 select count (*) from 表名
totalPages 总页数
totalPages=totalRecouds%pageSize==0?totalRecouds/pageSize:totalRecouds/pageSize+1
pages 计算前pages 条数据
pages= pageSize*(pageNumber-1)
SQL语句:
select top pageSize * from 表名 where id not in (select top pages id from 表名
order by id) order by id
第二种分页方法
pageSize 每页显示多少条数据
pageNumber 页数
从客户端传来
pages=pageSize*(pageNumber-1)+1
select top pageSize * from 表名
where id>=(select max(id) from (select top pages id from 表名 order by id asc )
t )
mysql分页
需用到的参数:
pageSize 每页显示多少条数据
pageNumber 页数 从客户端传来
totalRecouds 表中的总记录数 select count (*) from 表名
totalPages 总页数
totalPages=totalRecouds%pageSize==0?totalRecouds/pageSize:totalRecouds/pageSize+1
pages 起始位置
pages= pageSize*(pageNumber-1)
SQL语句:
select *
from 表名 limit pages, pageSize;
mysql 分页依赖于关键字 limit 它需两个参数:起始位置和pageSize
起始位置=页大小*(页数-1)
起始位置=pageSize*(pageNumber -1)
oracle分页
pageSize 每页显示多少条数据
pageNumber 页数 从客户端传来
totalRecouds
表中的总记录数 select count (*) from 表名
totalPages 总页数
totalPages=totalRecouds%pageSize==0?totalRecouds/pageSize:totalRecouds/pageSize+1
startPage 起始位置
startPage=
pageSize*(pageNumber-1)+1
endPage=startPage+pageSize
SQL语句
select
a.* from
(
select rownum num ,t.* from 表名 t where 某列=某值 order by id
asc
)a
where a.num>=startPage and a.num<endPage
db2分页
int startPage=1 //起始页
int endPage; //终止页
int
pageSize=5; //页大小
int pageNumber=1 //请求页
startPage=(pageNumber-1)*pageSize+1
endPage=(startPage+pageSize);
SQL语句
select * from (select 字段1,字段2,字段3,字段4,字段5,rownumber()
over(order by 排序字段 asc ) as rowid from 表名 )as a where a.rowid >= startPage
AND a.rowid <endPage
access分页
pageSize 每页显示多少条数据
pageNumber 页数
从客户端传来
pages=pageSize*(pageNumber-1)+1
SQL语句
select top pageSize *
from 表名 where id>=(select max(id) from (select top pages id from 表名 order by
id asc ) t )
最新文章
- redis pub/sub 实战: 微信语音识别
- C#中使用委托、接口、匿名方法、泛型委托实现加减乘除算法
- 【循序渐进学Python】6.Python中的函数
- BestCoder14 1002.Harry And Dig Machine(hdu 5067) 解题报告
- HTTP 错误 404.2 - Not Found
- struts2文件上传大小限制问题小结
- C#中显/隐式实现接口及其访问方法
- C#字符串拼接怎么转义背景图片
- LIS n*log(n)的理解
- Android 4.4 Kitkat Phone工作流程浅析(六)__InCallActivity显示更新流程
- webdynpro 下拉列表控件
- 怎么在ubuntu上运行php代码?
- C盘无损扩容
- python针对端口11211进行全网收集
- 开源:Taurus.MVC 框架 (已支持.NET Core)
- Chrome浏览器自动填充<;input>;标签的密码
- SharePoint 特殊用户标识
- P1005 矩阵取数游戏(动态规划+高精度)
- Continuous Integration for iOS Apps with Visual Studio Team Services
- Android adb你真的会用吗?
热门文章
- dmesg 信息实时监控其改变
- Android实例-打电话、发短信和邮件,取得手机IMEI号(XE8+小米2)
- matlab s变换
- sudo: /etc/sudoers is mode 0640, should be 0440解决办法
- JS幻灯片,循环播放,滚动导航,jQuery平滑旋转幻灯片
- ios项目不能再用UDID了
- php throw new Excpetion()之后,程序还往下继续运行吗?
- Codeforces Round #322 (Div. 2) C. Developing Skills 优先队列
- 【转】通过CMD命令设置定时关机及ShutDown命令大全
- 获取用户ip接口