Oracle数据库查询高效分页

数据库 Oracle 数据库运维
今天我们将谈到Oracle数据库查询高效分页,分页的控件实在很方便,以前的处理方式就是数据都拿出来,然后由控件进行处理,一般数据量不大的时候应该说感觉不出来优劣,但由于每次从数据库取的时候都是取所有的数据,肯定会增加数据库的压力,传输的数据库多了对网络带宽也会产生压力的。

由于网页渲染速度的影响,在C/S程序中那种一个Grid包含几千、上万行的数据基本上在网页是无法展现的,因此一般采用分页的形式显示(也可能采用Visual Srolling方式加载的,企业应用系统的不是很常见),ASP.NET 的数据控件一般带有分页功能,3.5以后还提供了单独的分页控件,也有用过AspNetPager这个第三方的组件。

分页的控件实在很方便,以前的处理方式就是数据都拿出来,然后由控件进行处理,一般数据量不大的时候应该说感觉不出来优劣,但由于每次从数据库取的时候都是取所有的数据,肯定会增加数据库的压力,传输的数据库多了对网络带宽也会产生压力的。很有可能查出来1万条数据,***显示只用到启用50条,翻页的时候又重新去查1万条数据,显示之后的的又50条。

以下的分页SQL比较常见的,在SQL Server也有对应的使用TOP关键字的版本,记得刚学Oralce的时候就想着怎么不能rownum between minValue and maxValue的用法。与最初的疑惑的原理一样,rownum是在查询过程中生成的,因此以下的SQL其实是查出来5300行,然后扔掉了前面5000行,返回后面的300行。当然这种已经进了一大步的,由数据库返回的数据变少的,只是当查询的页数比较大的时候,查询还是存在一定的浪费。

  1. select * 
  2.   from (select a.*, rownum as rnum 
  3.           from (select * from yz_bingrenyz) a 
  4.          where rownum <=5300) 
  5.  where rnum >= 5000 

       Linq提供了Skip和Take的API可以用于分页,由于使用的是Entity Framework,在好奇的驱使下用EFProfiler查看生成的SQL,才知道这样以下分页更好。 主要就是使用了row_numer()over()这样的分析函数,可以直接找到那第5000行开始的地方,然后在取出30行就行了。

  1. select * 
  2.   from (select * 
  3.           from (select t.*, 
  4.                        row_number() OVER(ORDER BY nullAS "row_number" 
  5.                   from yz_bingrenyz t) p 
  6.          where p."row_number" > 5000 
  7.         ) q 
  8.  where rownum <= 30 

比较分析:

本机测试前者耗时1.3s,后者仅0.25s,从以下的执行计划也能看出差异来。

 

L42E79ANC}UAF1O9XP%0MG8

image

实际应用

       如果每次查询都要写这种SQL那肯定比较麻烦,可以采用存储过程进行封装,但由于要动态执行SQL,效率肯定又要打折扣,所以在ASP.NET中用C#封装函数比较好,对于没有使用实体框架的而用ADO.NET的,传入表名 、主键名、页数、要取的行数作为参数,用DBCommand进行执行返回结果即可。

原文链接:http://www.cnblogs.com/xiaopang2010/archive/2012/07/23/2604880.html

【编辑推荐】

  1. 如何在Oracle中使用Java存储过程(详解)
  2. 任重道远迁移路之DB2到Oracle
  3. 11个重要的数据库设计规则
  4. 让数据库变快的10个建议
  5. 20个数据库设计***实践

【责任编辑:彭凡 TEL:(010)68476606】
责任编辑:彭凡 来源: 博客园
相关推荐

2011-08-19 09:30:42

分页查询SQL ServerMySQL

2009-05-15 10:11:55

数据库查询查询性能分页浏览

2010-10-26 15:21:11

连接Oracle数据库

2011-08-15 10:22:19

分页查询数据库

2011-03-14 15:47:33

Oracle数据库

2010-10-27 17:11:35

oracle查询

2009-01-11 17:32:03

Oracle数据库重复数据

2010-10-28 16:46:23

查询Oracle数据库

2009-11-18 16:16:51

Oracle数据库

2009-07-01 10:01:33

JSP分页查询MySQL数据库

2010-10-27 10:11:07

Oracle分页查询

2023-10-09 18:13:14

MySQL数据库查询

2017-11-29 13:11:37

PythonOracle中文查询报错

2019-07-03 09:35:20

Oracle数据库监听

2011-03-11 16:25:53

Oracle数据库

2011-08-16 16:37:40

Oracle数据库树形查询根节点

2010-03-30 18:48:24

Oracle 学习

2011-03-01 16:30:55

Oracle

2010-04-07 17:45:22

Oracle位图索引

2011-05-19 13:25:14

Oracle数据库
点赞
收藏

51CTO技术栈公众号