zoukankan      html  css  js  c++  java
  • 分页查询sql

     

    常用分页查询sql

    先介绍一个面试题,查询表中第200-300条数据。应用既是分页查询,先通过子查询对数据进行标记,如oracle通过rownum进行标记,再取一个区间的数据。

    一,ORACLE

    关键字 rownum

    规则:  

     select * from (select a.*,rownum rc from 表名 where rownum<=endrow) a where a.rc>=startrow

    SELECT *
      FROM (SELECT A.*, ROWNUM RN
              FROM (SELECT * FROM TABLE_NAME) A
             WHERE ROWNUM <= 40)
     WHERE RN > 20
    

    其中的SELECT * FROM TABLE_NAME 表示没有进行分页时的sql查询语句,而ROWNUM 和RN 限定了查询数据的范围。

    实例:

       select * from ( select OL.*, rownum  rc from OffsiteOutreachTeam_List OL where rownum <= 48 ) OL where OL.rc >= 9      

       SELECT * FROM (SELECT A.*, ROWNUM RN FROM (SELECT * FROM OffsiteOutreachTeam_List) A WHERE ROWNUM <= 40) WHERE RN > 20      

      select * from ( select OL.*, rownum rc from OffsiteOutreachTeam_List OL) where rc >= 9 and rc <= 20

      select * from ( select OL.*, rownum rc from OffsiteOutreachTeam_List OL) where rc between 10 and 20

      注意:可以通过排序,避免不同页出现重复的数据。

    1.   SELECT * FROM  
    2.   2  (  
    3.   3  SELECT A.*, ROWNUM RN  
    4.   4  FROM (SELECT ID, OWNER, OBJECT_NAME FROM TEST WHERE OWNER IS NOT NULL ORDER BY OWNER, ID) A  
    5.   5  WHERE ROWNUM <= 20  
    6.   6  )  
    7.   7  WHERE RN >= 11;

     

    二,MySQL

    关键字:limit

    MySQL数据库分页     Select * from 表名 limit startrow,pagesize     (Pagesize为每页显示的记录条数)    

    三,SQL Servel

    关键字:top

       3.SQL Server 2000数据库分页     Select top pagesize * from 表名 where 列名 not in(select top pagesize*page 列名 from 表名 order by列名) order by列名

       4.SQL Server 2005数据库分页     Select * from (select 列名,row_number() over(order by 列名1) as 别名from 表名) as t where t.列名1>=startrow and t.列名1<=endrow    

  • 相关阅读:
    工作单元(UnitOfWork) 模式 (2) .NET Core
    工作单元(UnitOfWork) 模式 (1)
    WebAPI规范设计——违RESTful
    ASP.NET MVC / WebAPI 路由机制详解
    C#封装HttpClient工具类库(.NET4.5以上)
    centos7多网卡配置bond0 (mode6无需交换机做配置)
    linux windows 格式化一块大于2 TiB硬盘
    war包安装jenkins
    redis(一主两从三哨兵模式搭建)记录
    nginx + keepalived 主从模式
  • 原文地址:https://www.cnblogs.com/pal857/p/12489582.html
Copyright © 2011-2022 走看看