mysql和oracle分页

Posted simeonwu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql和oracle分页相关的知识,希望对你有一定的参考价值。

https://my.oschina.net/realfighter/blog/349867

 链接地址:http://www.xx566.com/detail/143.html

  以前总结过一篇,Oracle分页查询语句的优化,当时对Oracle分页语句也着实花费了点时间记忆,不过今天在面试的时候,又考到了不同数据库的分页sql语句,对Oracle数据库的书写又存在了问题,以为很熟悉的分页sql书写起来也生疏了许多,这里再继续总结和整理一下,加深记忆。

 

    mysql的分页相对Oracle数据库来说,最是简单,通过提供的Limit关键字,即可方便的实现分页,如下:

SELECT
  *
FROM testTable
WHERE 1 = 1
LIMIT 1, 20;

 

     Oracle的分页sql,传统的是通过rownum,来进行分页,如下:

SELECT
  *
FROM (SELECT
        T1.*,
        ROWNUM rn
      FROM (SELECT
              *
            FROM testTable
            ORDER BY id DESC) T1
      WHERE ROWNUM <= 20)
WHERE rn > 0;

 

      不过上面的分页sql在数据量庞大的时候,越往后的分页查询会越缓慢,还有另外的一种效率很高的分页查询,通过rownum和rowid来进行分页,如下:

SELECT
  t1.*
FROM testTable t1, (SELECT
                      rid
                    FROM (SELECT
                            ROWNUM rn,
                            t.rid
                          FROM (SELECT
                                  ROWID rid
                                FROM testTable
                                WHERE 1 = 1) t
                          WHERE ROWNUM <= 20)
                    WHERE rn > 0) t2
WHERE 1 = 1 AND t1.ROWID = t2.rid;

 

    总结:分页的应用在各式各样的系统中,都是必不可少的组成部分,对分页sql的应用和优化也一直是程序开发中的重要成分,需要不断的记忆和总结。

 

以上是关于mysql和oracle分页的主要内容,如果未能解决你的问题,请参考以下文章

mysql和oracle分页

oracle和mysql的分页(转)

关于oracle分页顺序问题,我的代码可以实现分页,但是新添加进去的,顺序不是在最后

oracle sqlserver mysql数据库分页

mysql和oracle分页

MySQL 百万级分页优化(Mysql千万级快速分页)