zoukankan      html  css  js  c++  java
  • 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 )


     温馨提示:您的每一次转载,体现了我写此文的意义!!!烦请您在转载时注明出处http://www.blogjava.net/sxyx2008/谢谢合作!!!

  • 相关阅读:
    【第一季】CH06_FPGA设计Verilog基础(三)
    【第一季】CH05_FPGA设计Verilog基础(二)Enter a post title
    【第一季】CH04_FPGA设计Verilog基础(一)Enter a post title
    [第二季ZYNQ] [南京米联]ZYNQ第二季更新完毕课程共计16节课
    第十四章 ZYNQ TIMER定时器中断
    第十三章 ZYNQ-MIZ702 PL中断请求
    第十二章 ZYNQ-MIZ702 PS读写PL端BRAM
    bzoj3876 [Ahoi2014&Jsoi2014]支线剧情
    bzoj3698 XWW的难题
    bzoj2055 80人环游世界
  • 原文地址:https://www.cnblogs.com/zjoch/p/6405930.html
Copyright © 2011-2022 走看看