最近把平时在项目中常用到的数据库分页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 )

最新文章

  1. redis pub/sub 实战: 微信语音识别
  2. C#中使用委托、接口、匿名方法、泛型委托实现加减乘除算法
  3. 【循序渐进学Python】6.Python中的函数
  4. BestCoder14 1002.Harry And Dig Machine(hdu 5067) 解题报告
  5. HTTP 错误 404.2 - Not Found
  6. struts2文件上传大小限制问题小结
  7. C#中显/隐式实现接口及其访问方法
  8. C#字符串拼接怎么转义背景图片
  9. LIS n*log(n)的理解
  10. Android 4.4 Kitkat Phone工作流程浅析(六)__InCallActivity显示更新流程
  11. webdynpro 下拉列表控件
  12. 怎么在ubuntu上运行php代码?
  13. C盘无损扩容
  14. python针对端口11211进行全网收集
  15. 开源:Taurus.MVC 框架 (已支持.NET Core)
  16. Chrome浏览器自动填充&lt;input&gt;标签的密码
  17. SharePoint 特殊用户标识
  18. P1005 矩阵取数游戏(动态规划+高精度)
  19. Continuous Integration for iOS Apps with Visual Studio Team Services
  20. Android adb你真的会用吗?

热门文章

  1. dmesg 信息实时监控其改变
  2. Android实例-打电话、发短信和邮件,取得手机IMEI号(XE8+小米2)
  3. matlab s变换
  4. sudo: /etc/sudoers is mode 0640, should be 0440解决办法
  5. JS幻灯片,循环播放,滚动导航,jQuery平滑旋转幻灯片
  6. ios项目不能再用UDID了
  7. php throw new Excpetion()之后,程序还往下继续运行吗?
  8. Codeforces Round #322 (Div. 2) C. Developing Skills 优先队列
  9. 【转】通过CMD命令设置定时关机及ShutDown命令大全
  10. 获取用户ip接口