Oracle、DB2、SQLSERVER、Mysql、Access分页SQL语句
最近把平时在项目中常用到的数据库分页sql总结了下。大家可以贴出分页更高效的sql语句。sqlserver分页第一种分页方法 需用到的参数:pageSize 每页显示多少条数据pageNumber 页数 从客户端传来totalRecouds 表中的总记录数 select count (*) from 表名totalPages 总页数totalPages=totalRecouds%pageSize==0?totalRecouds/pageSize:totalRecouds/pageSize+1pages 计算前pages 条数据pages= pageSize*(pageNumber-1)SQL语句:select top pageSize * from 表名 where idnot 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+1pages 起始位置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+1startPage 起始位置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<endPagedb2分页 int startPage=1//起始页 int endPage; //终止页 int pageSize=5;//页大小 int pageNumber=1 //请求页 startPage=(pageNumber-1)*pageSize+1endPage=(startPage+pageSize); SQL语句 select * from (select 字段1,字段2,字段3,字段4,字段5,rownumber() over(order by 排序字段 asc ) as rowidfrom 表名 )as a where a.rowid >= startPage AND a.rowid <endPageaccess分页 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]