博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
oracle和mysql的分页
阅读量:7081 次
发布时间:2019-06-28

本文共 887 字,大约阅读时间需要 2 分钟。

(1)MySql的Limit m,n语句

Limit后的两个参数中,参数m是起始下标,它从0开始;参数n是返回的记录数。我们需要分页的话指定这两个值即可

(2)Oracle数据库的rownum

在Oracle数据库中,分页方式没有MySql这样简单,它需要依靠rownum来实现.

Rownum表示一条记录的行号,值得注意的是它在获取每一行后才赋予.因此,想指定rownum的区间来取得分页数据在一层查询语句中是无法做到的,要分页还要进行一次查询.

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

 其中最内层的查询SELECT * FROM TABLE_NAME表示不进行翻页的原始查询语句。ROWNUM <= 40和RN >= 21控制分页查询的每页的范围 

上面给出的这个分页查询语句,在大多数情况拥有较高的效率。分页的目的就是控制输出结果集大小,将结果尽快的返回。在上面的分页查询语句中,这种考虑主要体现在WHERE ROWNUM <= 40这句上。

选 择第21到40条记录存在两种方法,一种是上面例子中展示的在查询的第二层通过ROWNUM <= 40来控制最大值,在查询的最外层控制最小值。而另一种方式是去掉查询第二层的WHERE ROWNUM <= 40语句,在查询的最外层控制分页的最小值和最大值。这是,查询语句如下:

SELECT * FROM (SELECT A.*, ROWNUM RN FROM (SELECT * FROM TABLE_NAME) A )WHERE RN BETWEEN 21 AND 40

对比这两种写法,绝大多数的情况下,第一个查询的效率比第二个高得多。

这 是由于CBO优化模式下,Oracle可以将外层的查询条件推到内层查询中,以提高内层查询的执行效率。

转载于:https://www.cnblogs.com/tanlei-sxs/p/9958521.html

你可能感兴趣的文章
OKhttp3中的cookies
查看>>
客户端TortoiseSVN的安装及使用方法
查看>>
解决jsp访问jsp与Servlet访问jsp路径存在的差异性比较
查看>>
ACM,坚持到底!!!!
查看>>
数整型值数组求长度sizeof(a)/sizeof(int);
查看>>
泛型KMP算法
查看>>
XMLHttpRequest(ajax)跨域请求的优雅方法:CORS
查看>>
jQuery 练习[二]: 获取对象(3) - 根据属性、内容匹配, 还有表单元素匹配
查看>>
再学 GDI+[88]: TGPImage(8) - 放大镜
查看>>
mysql数据库同步详解
查看>>
JSON 之 SuperObject(5): Format 与转义字符
查看>>
Delphi 的内存操作函数(5): 复制内存
查看>>
YearsBetween、MonthsBetween ... YearSpan、MonthSpan ... 间隔时间
查看>>
python ConfigParser模块介绍
查看>>
使用本地光盘或iso来制作yum源
查看>>
与运算
查看>>
初尝Arduino
查看>>
linux 下 telnet 服务的安装和开启
查看>>
FTP服务搭建
查看>>
论项目的风险管理
查看>>