oracle 分页查询 优化_oracle分页查询封装

oracle 分页查询 优化_oracle分页查询封装对于数据库中表的数据的 Web 显示,如果没有展示顺序的需要,而且因为满足条件的记录如 此之多,就不得不对数据进行分页处理。常常用户并不是对所有数据都感兴趣的,或者大部分情 况下,他们只看前几页。 通常有以下两种分页技术可供选择。 1234567Select * from (Select rownumrn,t.* from table t)Where rn>&minnum and rn或者Sel

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

对于数据库中表的数据的 Web 显示,如果没有展示顺序的需要,而且因为满足条件的记录如 此之多,就不得不对数据进行分页处理。常常用户并不是对所有数据都感兴趣的,或者大部分情 况下,他们只看前几页。 

通常有以下两种分页技术可供选择。 

1
2
3
4
5
6
7
Select 

from 
(
Select 
rownum rn,t.* 
from 
table 
t)
Where 
rn>&minnum 
and 
rn<=&maxnum
或者
Select 

from 
(
Select 
rownum rn,t.* 
from 
table 
t rownum<=&maxnum)
Where 
rn>&minnum

看似相似的分页语句,在响应速度上其实有很大的差别。来看一个测试过程,首先创建一个测试表。 

1
SQL>
create 
table 
test 
as 
select 

from 
dba_objects;

并反复地插入相同数据。 

1
SQL>
insert 
into 
test 
select 

from 
test;

最后,查询该表,可以看到该表的记录数约为 80 万条。 

1
2
3
4
SQL> 
select 
count
(*) 
from 
test
  
COUNT
(*)
----------
    
831104

现在分别采用两种分页方式,在第一种分页方式中: 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
SQL> 
select 

from 
(
  
2  
select 
rownum rn,t.* 
from 
test t)
  
3  
where 
rn>0 
and 
rn <=50;
   
已选择50行。
已用时间:  00: 00: 01.03
   
Execution Plan
----------------------------------------------------------
   
0      
SELECT 
STATEMENT Optimizer=CHOOSE (Cost=10 Card=65 Bytes=12350)
   
1    0   
VIEW 
(Cost=10 Card=65 Bytes=12350)
   
2    1     
COUNT
   
3    2       
TABLE 
ACCESS (
FULL

OF 
'TEST' 
(Cost=10 Card=65 Bytes=5590)
   
Statistics
----------------------------------------------------------
          
0  recursive calls
          
0  db block gets
      
10246  consistent gets
          
0  physical reads
          
0  redo 
size
          
……

可以看到,这种方式查询第一页的一致性读有 10246 个,结果满足了,但是效率是很差的,如果采用第二种方式: 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
SQL> 
select 

from 
(
  
2  
select 
rownum rn,t.* 
from 
test t
  
3  
where 
rownum <=50)
  
4  
where 
rn>0;
  
已选择50行。
已用时间:  00: 00: 01.00
  
Execution Plan
----------------------------------------------------------
   
0      
SELECT 
STATEMENT Optimizer=CHOOSE (Cost=10 Card=50 Bytes=9500)
   
1    0   
VIEW 
(Cost=10 Card=50 Bytes=9500)
   
2    1     
COUNT 
(STOPKEY)
   
3    2       
TABLE 
ACCESS (
FULL

OF 
'TEST' 
(Cost=10 Card=65 Bytes=5590)
  
Statistics
----------------------------------------------------------
          
0  recursive calls
          
0  db block gets
         
82  consistent gets
          
0  physical reads
          
0  redo 
size
          
……

得到了同样的结果,一致性读只有 82 个,从以上的例子可以看到,通过把 rownum 引入到第 二层,却得到了一个完全不一样的执行计划,注意在执行计划中的 stopkey,它是 8i 引入的新操 作,这种操作专门为提取 Top n 的需求做了优化。 

从上面的例子可以再想到,因为 stopkey 的功能影响到了分页的一致性读的多少,会不会越往后翻页速度就越慢呢?事实也的确如此,例如: 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
SQL> 
select 

from 
(
  
2  
select 
rownum rn,t.* 
from 
test t
  
3  
where 
rownum <=10000)
  
4  
where 
rn>9950;
  
已选择50行。
已用时间:  00: 00: 01.01
  
Statistics
----------------------------------------------------------
          
0  recursive calls
          
0  db block gets
       
2616  consistent gets
          
0  physical reads
          
0  redo 
size
         
……

选择靠后一点的数据时,逻辑读开始变大,当选择到最后几页时,一致性读已经与上面的相似了。 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
SQL> 
select 

from 
(
  
2  
select 
rownum rn,t.* 
from 
test t
  
3  
where 
rownum <=800000)
  
4  
where 
rn>799950;
  
已选择50行。
已用时间:  00: 00: 01.03
  
Statistics
----------------------------------------------------------
          
0  recursive calls
          
0  db block gets
      
10242  consistent gets
          
0  physical reads
          
0  redo 
size
          
……

不过,所幸的是,大部分的用户只看开始 5%的数据,而没有兴趣看最后面的数据,通过第二种改良的分页技术,可以方便快速地显示前面的数据,而且不会让用户感觉到慢。 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/213589.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 单片机:STC89C52的最小单元「建议收藏」

    单片机:STC89C52的最小单元「建议收藏」STC89C52RC是STC公司生产的一种低功耗、高性能CMOS8位微控制器,具有8K字节系统可编程Flash存储器。STC89C52使用经典的MCS-51内核,但做了很多的改进使得芯片具有传统51单片机不具备的功能。在单芯片上,拥有灵巧的8位CPU和在系统可编程Flash,使得STC89C52为众多嵌入式控制应用系统提供高灵活、超有效的解决方案。中文名STC89C52本    质一种低耗高

    2022年8月30日
    4
  • 在毕设中学习01——python、正态和标准正态分布、matlab数据文件导出

    在毕设中学习01——python、正态和标准正态分布、matlab数据文件导出在毕设中学习——卷积、python(0521)2022.5.21文章目录在毕设中学习——卷积、python(0521)正态分布标准正态分布matplotlib.pyplot画图Python中读取.m文件np.random.normal()正态分布numpy.random.normal(loc=0,scale=1e-2,size=shape)意义如下:参数loc(float):正态分布的均值,对应着这个分布的中心。loc=0说明这一个以Y轴为对称轴的正态分布,参数scale(float):

    2022年8月11日
    6
  • bug生命周期流程_bug六大要素

    bug生命周期流程_bug六大要素你们公司是如何管理bug的?考查点:缺陷的生命周期常见的流程就不多说了,CSDN上有很多,今天说一些不一样的点:正常流程:打开–接受–已解决-关闭其它状态:拒绝、重新打开、遗留1、线上的bug优先级最高,会要求测试leader亲自协助运营、开发人员定位,邮件报告相关领导:bug分析、开发人员如何修改,有哪些影响范围,bug修改进度,开发和测试的改进措施;2、测试环境的典型b…

    2022年10月20日
    4
  • window到linux文件名乱码和文件内容乱码解决总结「建议收藏」

    window到linux文件名乱码和文件内容乱码解决总结「建议收藏」    window系统一般文件名编码为gbk,文件内容编码这个需要通过编辑器查看或者设置,找个editplus文本编辑器就可以处理文本内容编码。    那么在window上显示正常的文件到linux上的时候,常常会因为中文问题导致乱码,比如文件名乱码和文件内容乱码。查看linux设置的编码:[root~]# echo$LANGzh_CN.UTF-8[root…

    2022年4月19日
    647
  • Linux学习——shell编程之变量

    shell编程之变量:Linux shell编程基础中的变量。 包括Bash变量的分类和各变量的详细使用,如:用户自定义变量、环境变量、语系变量、位置参数变量和预定义变量。

    2022年2月26日
    44
  • 详细SpringBoot教程之Web开发(一)

    写在前面鉴于有人留言说想要学习SpringBoot相关的知识,我这里打算写一个SpringBoot系列的相关博文,目标呢是想让看了这一系列博文的同学呢,能够对SpringBoot略窥门径,这一系列的博文初步都定下来包括SpringBoot介绍、入门、配置、日志相关、web开发、数据访问、结合docker、缓存、消息队列、检索、任务安全、分布式等等一系列的博文,工作量很大,是个漫长的过程,每一步我…

    2022年4月14日
    44

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号